这样的函数类型定义在 ts 里面叫什么?

163 天前
 waiaan
type ClassA = {
  prop1: string
  prop2: number
  prop3?: string
}

const a = {
  prop4: '123',
  // 这个 prop5 是函数的类型定义吗?
  prop5: (): ClassA => {
    return {
      prop1: '1',
      prop2: 2
    }
  }
}

如何理解这个 prop5 的类型定义?有没有相关文档可以学习一下?谢谢。

1661 次点击
所在节点    TypeScript
9 条回复
edz
163 天前
去看一眼函数类型都能知道了吧
waiaan
163 天前
@edz

没找到文档里有这种写法
Track13
163 天前
prop5: (): ClassA 这里表示 prop5 这个函数的返回值是 ClassA 的实例
sunjourney
163 天前
@Track13 #3 这就是取了名叫 ClassA ,和 Class 没半毛钱关系
NoManPlay
163 天前
箭头函数类型的几种写法
const fn1 = (): number => {
return 1
};
const fn2 = (a: number, b: number): number => {
return a + b;
};
const fn3: (a: number, b: number) => number = (a, b) => {
return a + b;
};

type FnType = (a: number, b: number) => number;
const fn4: FnType = (a, b) => {
return a + b;
};

你给出的 prop5 对应 fn1 的写法
https://www.typescriptlang.org/docs/handbook/functions.html#function-types
ruyan2013
163 天前
"prop5 的类型定义" 这么表达,似乎不太准确,

这里 prop5 是一个对象上的 key ,值为一个函数,并不是“类型定义”。这里写的 ClassA 是在强制声明一下此函数返回值符合 ClassA 的类型定义。不写也没关系,这里 ts 可以推断也符合 ClassA
nitmali
163 天前
prop5 是函数名,

ClassA 是函数返回类型,

prop5: (): ClassA => {
return {
prop1: '1',
prop2: 2
}
}
是箭头函数
Track13
163 天前
@sunjourney type ClassA 前面不是有 type 吗。这不是一个 Class ,只是类型别名。
ParkinLin
153 天前
`prop5` 是 `a` 对象的箭头方法,不是类型定义,类型定义是 `prop5` 后面的 `(): ClassA` 这部分,只不过 `prop5` 是无参箭头方法,所以把你和类型定义的语法绕进去了......(我也被坑过!!!)
一种可视化的调试是,我们直接把代码复制到 TS 的在线游乐场,编译完就只剩下下面这些代码了:
```js
const a = {
prop4: '123',
// 这个 prop5 是函数的类型定义吗?
prop5: () => {
return {
prop1: '1',
prop2: 2
};
}
};
```
可以看到,代码中被擦除的和逻辑无关的部分就是 TS 的类型定义,剩下的则是 JS 的功能逻辑。
另外,ES5 之前的函数既可以是函数,也可以是 lambda 表达式,还可以是构造函数。ES6 之后,为了区分函数在不同编程范式中的语义,JS 引入箭头函数表示 lambda ,引入 class 表示构造函数。
这里的 `prop5` 虽然看似箭头函数,但由于它是 `a` 对象的属性,所以准确的术语是“箭头方法”。
( PS:这并不会影响我们修炼“类型体操”,只是表述更加专业。)

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1056453

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX