189 8069 5689

TypeScript泛型的相关知识点有哪些

本篇内容主要讲解“TypeScript泛型的相关知识点有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“TypeScript泛型的相关知识点有哪些”吧!

创新互联公司是一家专注于网站设计、成都网站建设与策划设计,忠县网站建设哪家好?创新互联公司做网站,专注于网站建设十年,网设计领域的专业建站公司;建站业务涵盖:忠县等地区。忠县做网站价格咨询:18982081108

1、ts的泛型很难吗?

如果你:

  1.  刚开始学ts

  2.  刚开始接触泛型

  3.  正在挣扎得学习ts的泛型

看到以下代码有没有很疑惑?

function makePair<    F extends number | string,    S extends boolean | F  >()

Java是和typescript一样支持泛型的,当我在大学开始学习Java的时候,我还是一个菜鸟码农,遇到难点(比如泛型)就直接跳过,能学多少学多少,回寝室就LOL开黑。直到大学毕业我依旧没有理解泛型的概念,可能你和我一样觉得泛型很难,下面我会分享我的理解,希望对你有所帮助。

2、一起来看一下makeState()这个函数

首先,我写了makeState这个函数,我们会用这个函数来讨论泛型

function makeState() {    let state: number    function getState() {      return state    }    function setState(x: number) {      state = x    }    return { getState, setState }  }

当你运行这个函数,我们会得到getState() 和 setState()这两个函数。

让我们来试一下,下面这段代码会打印出什么

const { getState, setState } = makeState()  setState(1)  console.log(getState())  setState(2)  console.log(getState())
1  2

会打印出1和2,没那么难对吧?

Note: 如果你正在使用react,你可能会发觉,makeState()和钩子函数useState()很像。这里也涉及到了闭包和ES6的解构赋值

3、我们传入字符串会如何?

我们把刚才给setState的入参1和2替换成字符串'foo'会输出什么呢?

const { getState, setState } = makeState()  setState('foo')  console.log(getState())
Argument of type '"foo"' is not assignable to parameter of type 'number'.

会编译失败,因为setState()需要的参数类型是number

我们可以用以下方法解决这个问题

function makeState() {    // Change to string    let state: string    function getState() {      return state    }    // Accepts a string    function setState(x: string) {      state = x    }    return { getState, setState }  }
const { getState, setState } = makeState()  setState('foo')  console.log(getState())
foo

4、挑战:获取两个不同类型的state

我们能不能修改makeState()这个函数,来输出两个不同类型的state,比如一个是字符串,一个是数字。

以下代码简略得表示我想表达的意思:

// One that only allows numbers, and…  const numState = makeState()  numState.setState(1)  console.log(numState.getState()) // 1  // The other that only allows strings.  const strState = makeState()  strState.setState('foo')  console.log(strState.getState()) // foo

要达到以上效果,我们可能需要创建两个内部不一样的makeState(),一个state的类型是数字,一个是字符串。

怎么用才能只写一个来实现呢?

5、实验一:设置多个类型

这是我们的第一个尝试:

function makeState() {    let state: number | string    function getState() {      return state    }    function setState(x: number | string) {      state = x    }    return { getState, setState }  }
const numAndStrState = makeState()  //数字  numAndStrState.setState(1)  console.log(numAndStrState.getState())  //字符串  numAndStrState.setState('foo')  console.log(numAndStrState.getState())
1  foo

结果看上去我们貌似成功了,但是这并不是我真实想要的,我们真正要实现的是只能输出数字state和只能输出字符串state。

numAndStrState是既能输出数字类型,又能输出字符串类型

6、实现二:使用泛型

接下来我们的泛型要登场了:

function makeState() {    let state: S    function getState() {      return state    }    function setState(x: S) {      state = x    }    return { getState, setState }  }

makeState() 被定义成 makeState(),你可以把当作函数参数,但它传入的不是值,而是类型。

比如你可以传入数字类型:

makeState()

在makeSate()这个函数内部state会变成数字类型

let state: S // <- number  function setState(x: S /* <- number */) {    state = x  }

这样就实现了只能输出数字state

// Creates a number-only state  const numState = makeState()  numState.setState(1)  console.log(numState.getState())  // numState.setState('foo') 输入字符串foo会报错

同理我们也可以实现只能输出字符串state

// Creates a string-only state  const strState = makeState()  strState.setState('foo')  console.log(strState.getState())  // strState.setState(1) 输入数字1会报错

Note: 我们把makeState()称作泛型函数,就是一个普通的函数支持类型参数的传入

你可能会疑惑为什么类型参数是S, 其实随便什么都可以,但是通常来说我们会用一个变量的第一个字母的大写来代表这个变量的类型:

  •   T(for“T”ype)

  •   E(for“E”lement)

  •   K(for“K”ey)

  •   V(for“V”alue)

7、泛型的类型范围限制

目前,在我们改进下的makeState()实现了只能输出数字state和只能输出字符串state。但是它也能实现输出布尔值。

// Creates a boolean-only state  const boolState = makeState()  boolState.setState(true)  console.log(boolState.getState())

问题:那么我们要如何限制它就只能输入输出number和string类型呢?

方法:声明makeState()这个函数时,把类型参数变为,这样就只能输入number或者string类型了

function makeState() {    let state: S    function getState() {      return state    }    function setState(x: S) {      state = x    }    return { getState, setState }  }  // 如果我传入boolean类型  const boolState = makeState()
Type 'boolean' does not satisfy the constraint 'string | number'.

8、泛型的默认类型

现在每次调用makeState()时,我们可以任意传入类型,那怎么设置一个默认类型呢?

比如让下面两个语句起到相同的作用:

const numState1 = makeState()  const numState2 = makeState()

其实和给函数参数设置默认值一样:

function makeState()

这样,变量state默认类型就是number了

const numState = makeState()  numState.setState(1)  console.log(numState.getState())

到此,相信大家对“TypeScript泛型的相关知识点有哪些”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!


网站标题:TypeScript泛型的相关知识点有哪些
文章地址:http://cdxtjz.cn/article/pgddeg.html

联系我们

您好HELLO!
感谢您来到成都网站建设公司,若您有合作意向,请您为我们留言或使用以下方式联系我们, 我们将尽快给你回复,并为您提供真诚的设计服务,谢谢。
  • 电话:028- 86922220 18980695689
  • 商务合作邮箱:631063699@qq.com
  • 合作QQ: 532337155
  • 成都网站设计地址:成都市青羊区锣锅巷31号五金站写字楼6楼

小谭建站工作室

成都小谭网站建设公司拥有多年以上互联网从业经验的团队,始终保持务实的风格,以"帮助客户成功"为已任,专注于提供对客户有价值的服务。 我们已为众企业及上市公司提供专业的网站建设服务。我们不只是一家网站建设的网络公司;我们对营销、技术、管理都有自己独特见解,小谭建站采取“创意+综合+营销”一体化的方式为您提供更专业的服务!

小谭观点

相对传统的成都网站建设公司而言,小谭是互联网中的网站品牌策划,我们精于企业品牌与互联网相结合的整体战略服务。
我们始终认为,网站必须注入企业基因,真正使网站成为企业vi的一部分,让整个网站品牌策划体系变的深入而持久。