当前位置: 首页 > news >正文

湛江今天发生的重大新闻seo手机端排名软件

湛江今天发生的重大新闻,seo手机端排名软件,wordpress菜单无效,潍坊专业网站建设多少钱泛型 目的&#xff1a;可重用性 支持当前数据类型&#xff0c;也支持未来的数据类型。 提供灵活的功能 无法创建泛型枚举和泛型命名空间。 function identity(arg: any): any { return arg }function identity<T>(arg: T) : T { return arg}使用any类型会导致这个函数可以…

泛型

目的:可重用性

支持当前数据类型,也支持未来的数据类型。

提供灵活的功能

无法创建泛型枚举和泛型命名空间。

function identity(arg: any): any { return arg }function identity<T>(arg: T) : T { return arg}

使用any类型会导致这个函数可以接受任何类型的 arg参数,

丢失了一些信息:传入的类型与返回的类型应该时相同的。我们传入一个数字,任何类型的值都有可能被返回。

类型变量

一种特殊的变量

function identity<T>(arg: T):T { return arg }

把 identity 函数叫做泛型

两种方法使用

定义泛型函数后,可以用两种方法使用

传入所有参数,包含类型参数-如:
let output = identity<string>('myString');

明确了 T 是 string 类型,并作为参数传给函数。

使用<>括起来

类型推论
let output = identity('myString')

类型推论帮助我们保持代码精简和高可读性。

使用泛型变量

function identity<T>(arg: T):T {console.log(arg.length)//报错return arg
}

使用泛型创建泛型函数时,必须把这些参数当做是任意或所有类型

因为 arg可能是任意类型,如果是数字的话是没有.length的 所以报错

  • 创建一个 T类型的数组作为参数的 泛型函数
function loggingIdentity<T>(arg: T[]) :T[] {console.log(arg.length)return arg
}

泛型类型

指泛型的接口,类似于 变量的类型

与非泛型函数的类型没什么不同,只是有个类型参数在最前面

function identity<G>(arg:G) :G {return arg}
let myIdentity: <G>(arg:G) => G = identity

带有调用签名的对象字面量第一泛型函数

let myIdentity: {<t>(arg:t):t} = identity

第一个泛型接口

#接口
interface GeneratorIdentity{<a>(arg:a):a;
}
# 定义
let myIdentity: GenericIdentityFn = function <T>(arg: T): T {return arg
}
# 使用
console.log(indentity<string>('Ren'))
  • 泛型参数当作接口的一个参数,这样就清楚的知道使用的具体是那个泛型类型了
interface GeneratorIdentity<T> {(arg: T): T
}
function identity<T>(arg: T): T { return arg }
let myIdentity: GeneratorIdentity<number> = identity
console.log(myIdentity(111))

接口中,非泛型函数签名作为了泛型类型的一部分

当使用接口时需要传入一个类型参数来指定泛型类型

泛型类

泛型类看上去与泛型接口差不多。 泛型类使用( <>)括起泛型类型,跟在类名后面。

class Generator<T> {zeroValue: T;add: (x:T) => T
}
let instance = new Generator<number>()
instance.zeroValue = 0
instancs.add = function(x) {return x}

泛型类指的是实例部分的类型, 所以类的静态属性不能使用这个泛型类型

泛型约束

定义一个接口来描述约束条件, 使用接口和extends关键字来实现约束

interface lengthwise {length: number;
}
function loggingIdentity<T extends Lengthwise>(arg: T): T {console.log(arg.length)return arg
}
loggingIdentity(1)//报错
loggingIdentity({length: 1, name: 'Ren'})

在泛型约束中使用类型参数

let x = {a: 1, b: 2, c: 3, d: 4}
function getProperty<T, K extend keyof T>(obj: T, key: K) {return obj[key]
}
console.log(getProperty(x,'a'))
console.log(getProperty(x,'g'))

keyof

在泛型里使用类类型

没懂

function create<T>(c:{new(): T}) :T {return new c()
}
http://www.mmbaike.com/news/57157.html

相关文章:

  • 做编辑器的网站通过qq群可以进行友情链接交换
  • 淘宝网站建设教程视频长沙优化科技有限公司
  • 南通网站建设公司百度关键词搜索
  • wordpress 发布工具太原seo优化
  • 专业做网站的软件下载百度官方版
  • 深度网营销型网站建设营销公司网站
  • 巩义网站推广优化搜索引擎的关键词优化
  • 给公司做网站怎么样站长统计网站
  • 做新零售这些注册网站和找货源6推广引流工具
  • 网站建设好如何开通结构优化
  • jquery效果网站湖南企业seo优化
  • 宁夏建设学院官方网站seo案例分析及解析
  • 网站seo排名优化软件百度搜索量
  • 电子商务网站建设人才广州网站优化方式
  • 专业网站 建设公司竞价sem托管
  • 怎么在电脑上做网站竞价推广和信息流推广
  • 潍坊优化网站排名靠前产品经理培训
  • 赤风设计宁波seo博客
  • 静海县建设委员会网站google推广费用
  • 自己做网站要钱么torrentkitty磁力猫
  • 中英文企业网站系统网络推广属于什么专业
  • 可信赖的广州做网站网站推广途径和推广要点
  • 做网站看好金石网络免费的行情软件网站下载
  • 做投票网站的常州网站关键词推广
  • 网站如何建设推广手机seo排名软件
  • 网站建设公司石家庄百度权重等级
  • 美橙互联网站建设案例百度收录网址
  • 苏州在线网站制作百度地图关键词优化
  • 博业建站网青岛seo精灵
  • 深圳网站建设 网站设计长沙企业seo优化