美文网首页
泛型函数、泛型接口、泛型类、泛型约束

泛型函数、泛型接口、泛型类、泛型约束

作者: 我性本傲 | 来源:发表于2019-11-27 16:00 被阅读0次

很多时候我们需要一个函数或者一个类支持多种数据类型。

泛型:

概念:不预先确定的数据类型,具体的类型在使用的时候才能确定。
好处:1.函数和类可以轻松地支持多种类型,增强程序的扩展性
2.不必写多条函数重载,冗长的联合类型声明,增强代码可读性
3.灵活控制类型之间的约束

泛型函数
function log<T> (value: T): T {
  console.log(value)
  return value;
}
log<string[]>(['a','b'])  // 调用
log(['a','b'])    // 类型推断 调用
泛型函数类型
 type Log = <T>(value: T) => T
let myLog: Log  = log
泛型接口
 interpace Log<T> {
     (value: T) : T
 }
let  myLog: Log<number>  = log
myLog(1)

 interpace Log<T = string> {
     (value: T) : T
 }
let  myLog: Log  = log
myLog('1')
泛型类
class Log<T> { // 约束所有类的成员,但是不能约束static成员
  run(value: T) {
    console.log(value)
    return value
  }
}
let log1 = new Log<number>()
log1.run(1) //值必须为number类型
let log2 = new Log() //当不指定类型参数的时候,value的值可以是任意的值
log2.run({a:1})
log2.run('111')
泛型约束
  function log<T extends Length> (value: T): T {  // 让类型T继承Length接口
    console.log(value, value.length) // 打印length属性,提示T类型上不存在length属性
    return value;
  }
  不存在length属性,这时候用到泛型约束
   interface Length {
       length: number
   }
   log([111])
   log(['1231'])
   log({length: 1})
   // 以上只要有length属性都可以

相关文章

  • 【Swift】泛型常见使用

    1、Swift泛型4种 泛型函数泛型类型泛型协议泛型约束 2、泛型约束3种 继承约束:泛型类型 必须 是某个类的子...

  • Swift 泛型

    泛型函数 泛型类型 泛型约束

  • typescript入门-泛型

    基础定义 泛型接口 泛型类 泛型约束 使用类类型

  • TypeScript 泛型

    泛型函数 使用 数组 类 泛型约束

  • TS 泛型+装饰器

    typescript 中的泛型 泛型的定义泛型函数泛型类泛型接口 泛型:软件工程中,我们不仅要创建一致的定义良好的...

  • 泛型函数、泛型接口、泛型类、泛型约束

    很多时候我们需要一个函数或者一个类支持多种数据类型。 泛型: 概念:不预先确定的数据类型,具体的类型在使用的时候才...

  • swift泛型整理

    swift泛型知识主要包括:泛型函数、泛型协议、泛型类型、泛型约束。 一、泛型函数。 如:一个交换两个变量值的函数...

  • Kotlin语言(六):泛型

    1、泛型类 2、泛型函数 3、泛型上限 4、泛型擦除 5、泛型投射 6、星号投射

  • 泛型的使用

    泛型有三种使用方式,分别为:泛型类、泛型接口、泛型方法 泛型类 泛型接口 泛型通配符 泛型方法 静态方法与...

  • TypeScript 学习笔记4 泛型

    1.泛型 1.1 泛型函数 1.2 泛型类 1.3 泛型接口 Typescript从0到1-学习视频教程-培训课程...

网友评论

      本文标题:泛型函数、泛型接口、泛型类、泛型约束

      本文链接:https://www.haomeiwen.com/subject/dqipwctx.html