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

修改网站默认首页朋友圈广告推广文字

修改网站默认首页,朋友圈广告推广文字,网站怎么上传源码,wordpress功能文件夹一、什么是泛型? 泛型,从字面上理解,泛型就是一般的,广泛的的意思。 TypeScript中泛型(Generics)是指在定义函数、接口或类的时候,不预先指定具体类型,而是在使用的时候再指定类型…

一、什么是泛型?

泛型,从字面上理解,泛型就是一般的,广泛的的意思。

TypeScript中泛型(Generics)是指在定义函数、接口或类的时候,不预先指定具体类型,而是在使用的时候再指定类型的一种特性。

泛型中的 T 就像一个占位符、或者说一个变量,在使用的时候可以把定义的类型像参数一样传入,它可以原封不动地输出。
泛型在成员之间提供有意义的约束,这些成员可以是:函数参数、函数返回值、类的实例成员、类的方法等。

二、使用泛型的好处

  1. 函数和类可以轻松支持多种类型,增强程序的拓展性
  2. 不必写冗长的业务代码,增强代码的可拓展性
  3. 灵活控制类型之间的约束

三、泛型的基本使用

1. 处理函数参数

泛型的语法是尖括号 <> 里写类型参数,一般可以用T来表示。

定义一个 print 函数,这个函数的功能是把传入的参数打印出来,再返回这个参数,传入参数的类型与函数返回类型一致。

function print<T>(arg:T):T {console.log(arg);return arg;
}

这样,我们就做到了输入和输出的类型统一,且可以输入输出任何类型

泛型的写法对前端工程师来说是有些古怪,比如 <T> ,但记住就好,只要一看到 <>,就知道这是泛型。

我们在使用的时候可以有两种方式指定类型:

  • 定义要使用的类型
  • TS 类型推断,自动推导出类型
print<string>('hello')  // 定义 T 为 stringprint('hello')  // TS 类型推断,自动推导类型为 string

当然也可以结合类型别名type与接口interface使用.

类型别名用来给一个类型起个新名字(它并不是一个类型,只是一个别名而已)。常用于联合类型。
接口来定义对象的类型,除了可用于对类的一部分行为进行抽象以外,也常用于对「对象的形状(Shape)」进行描述。

type 这么写:

type Print = <T>(arg: T) => T
const printFn:Print = function print(arg) {console.log(arg)return arg
}

interface 这么写:

interface Iprint<T> {(arg: T): T
}function print<T>(arg:T) {console.log(arg)return arg
}const myPrint: Iprint<number> = print

2. 默认参数

如果要给泛型加默认参数,可以这么写:

interface Iprint<T = number> {(arg: T): T
}function print<T>(arg:T) {console.log(arg)return arg
}const myPrint: Iprint = print

这样默认就是 number 类型了,怎么样,是不是感觉 T 就如同函数参数一样呢?

3. 处理多个函数参数

现在有这么一个函数,传入一个只有两项的元组,交换元组的第 0 项和第 1 项,返回这个元组。

数组合并了相同类型的对象,而元组(Tuple)合并了不同类型的对象。
let tom: [string, number] = [‘Tom’, 25]; // 定义一对值分别为 string 和 number 的元组

function swap(tuple) {return [tuple[1], tuple[0]]
}

这么写,我们就丧失了类型,用泛型来改造一下。

我们用 T 代表第 0 项的类型,用 U 代表第 1 项的类型。

function swap<T, U>(tuple: [T, U]): [U, T]{return [tuple[1], tuple[0]]
}

这样就可以实现了元组第 0 项和第 1 项类型的控制。方便编辑器提示。

4. 函数副作用操作

泛型不仅可以很方便地约束函数的参数类型,还可以用在函数执行副作用操作的时候。

比如我们有一个通用的异步请求方法,想根据不同的 url 请求返回不同类型的数据。

function request(url:string) {return fetch(url).then(res => res.json())
}
// 调一个获取用户信息的接口:
request('user/info').then(res =>{console.log(res)
})

这时候的返回结果 res 就是一个 any 类型,非常讨厌。

我们希望调用 API 都清晰的知道返回类型是什么数据结构,就可以这么做:

interface UserInfo {name: stringage: number
}function request<T>(url:string): Promise<T> {return fetch(url).then(res => res.json())
}request<UserInfo>('user/info').then(res =>{console.log(res)
})

如果我的文章对你有帮助,你的赞👍就是对我的最大支持_

https://juejin.cn/post/7064351631072526350
https://juejin.cn/post/7193917621069152311

http://www.yayakq.cn/news/674186/

相关文章:

  • wordpress显示网站运行网站做百度推广有没有效果
  • 广西临桂建设局网站要学做网站
  • 企业网站优化技巧WordPress信息收集
  • 做政协网站的目的是什么wordpress 网站加载过慢6
  • flash网站设计实例wordpress 子菜单顺序
  • 网站找人做seo然后网站搜不到了wordpress调用目录
  • 家乡网站设计目的wordpress如何设置邮箱验证码
  • 镇网站制作价格做网站需注意什么
  • 阿里云个人网站备案做网站商铺模板
  • 顺德网站建设公司咨询wordpress博客简洁主题
  • 广州 企业网站建设ios软件开发需要学什么
  • 做三年网站需要多少钱做网站的怎么赚钱
  • 江西省住房和城乡建设厅的网站怎么制作自己的小网站
  • 广西网站建设证件查询信誉好的做网站公司
  • 网站建设空格怎么打电子商务网站建设与管理实验
  • 天动力网站开发网站建设 开发
  • 景德镇网站建设哪家好二维码图片生成器在线制作
  • 网站开发电子书欧洲c2c平台
  • 好的摄影网站移动宽带可以在网上续费吗
  • 网站接单园区网站建设调研报告
  • 下载类网站 前置备案临安市建设局网站
  • 旅游建设网站目的及功能定位珠海市外贸网站建设公司
  • 网站建站网站网站维护给人做违法网站规避
  • 网站项目需求说明书响应式网站的宽度
  • 旅游网站设计的目的与意义网站会员系统wordpress
  • 政协网站建设天津网站开发建设公司
  • 深圳建设集团网站官网响应式网站模板分享
  • 儿童玩具网站建设实训报告跳转链接
  • 做彩票网站推广网站的导航栏
  • 怎么开网店详细步骤教程权威网站优化价格