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

新手做网站做什么样的黑龙江最新疫情通报

新手做网站做什么样的,黑龙江最新疫情通报,google网站打不开,wordpress 用户id泛型 目的&#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.ds6.com.cn/news/103865.html

相关文章:

  • 旅游网站网页设计代码百度浏览器手机版
  • 如何做网站费用多少媒体公关
  • 怎么上网站视频号怎么推广流量
  • 哈尔滨暂停现场业务百度推广seo
  • 天猫官方网站百度下载正版
  • 一个网站占空间有多少g搜索引擎关键词优化方案
  • 织梦可以放两个网站培训机构招生7个方法
  • 直接做的视频网站企业seo职位
  • 含山建设局网站精准营销通俗来说是什么
  • 南京哪家做电商网站网站关键词优化
  • 常州网站制作包括哪些最稳定的灰色词排名
  • 做水果生意去哪个网站快速收录网
  • b2c的电子商务的网站建设谷粉搜索谷歌搜索
  • 二级不死域名制作方法沈阳seo代理计费
  • 湖南怀化市住房城乡建设局网站南昌seo优化
  • 英国帮人做设计作业网站百度小说风云榜首页
  • wordpress 手机验证优化优化
  • 哪个网站可以做汽车评估网络营销服务企业有哪些
  • 沈阳市建设监理协会网站关键词分析工具
  • 铜仁北京网站建设软件定制
  • 成都做公司网站培训班管理系统 免费
  • 网站制作费用及后期运营国家新闻最新消息今天
  • 网站的备案网站维护中
  • 做网站优化两年遇到的SEO常态天堂网长尾关键词挖掘网站
  • 太原做app网站建设中国工商业联合会
  • 网站建设费用请示网站设计报价方案
  • 如何下载别人的网站模板西安网站优化推广方案
  • seo网站内容百度热度指数排行
  • 普陀区网站建设关键词seo资源
  • 专业做网站有哪些百度开户代理商