博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
TypeScript基础入门 - 接口 - 函数类型
阅读量:7109 次
发布时间:2019-06-28

本文共 1255 字,大约阅读时间需要 4 分钟。

转载地址

项目实践仓库

https://tag: 1.0.10

为了保证后面的学习演示需要安装下ts-node,这样后面的每个操作都能直接运行看到输出的结果。

npm install -D ts-node

后面自己在练习的时候可以这样使用

npx ts-node src/learn_basic_types.ts
npx ts-node 脚本路径

接口

TypeScript的核心原则之一是对值所具有的结构进行类型检查。 它有时被称做“鸭式辨型法”或“结构性子类型化”。 在TypeScript里,接口的作用就是为这些类型命名和为你的代码或第三方代码定义契约。

函数类型

接口能够描述JavaScript中对象拥有的各种各样的外形。 除了描述带有属性的普通对象外,接口也可以描述函数类型。

为了使用接口表示函数类型,我们需要给接口定义一个调用签名。 它就像是一个只有参数列表和返回值类型的函数定义。参数列表里的每个参数都需要名字和类型。如下示例

interface SomeInterface {  (arg1: string, arg2: string): boolean;}

这样定义后,我们可以像使用其它接口一样使用这个函数类型的接口。 下例展示了如何创建一个函数类型的变量,并将一个同类型的函数赋值给这个变量。

let someFunc: SomeInterfacesomeFunc = function (arg1: string, arg2: string) {    const res = arg1.search(arg2)    return res > -1;}console.log(someFunc('weast','east'));

运行后得到的结果如下

true

对于函数类型的类型检查来说,函数的参数名不需要与接口里定义的名字相匹配。 比如,我们使用下面的代码重写上面的例子:

let someFunc2: SomeInterface;someFunc2 = function (x: string, y: string): boolean {    const res = x.search(y);    return res > -1;}console.log(someFunc2('weast', 'east'));

运行后得到的结果如下

true

函数的参数会逐个进行检查,要求对应位置上的参数类型是兼容的。 如果你不想指定类型,TypeScript的类型系统会推断出参数类型,因为函数直接赋值给了 someInterface类型变量。 函数的返回值类型是通过其返回值推断出来的(此例是 false和true)。 如果让这个函数返回数字或字符串,类型检查器会警告我们函数的返回值类型与someInterface接口中的定义不匹配。

本实例结束实践项目地址

https://github.com/durban89/typescript_demo.gittag: 1.0.11

 

你可能感兴趣的文章
结对-英文词频检测-结对项目总结
查看>>
php随机生成汉字
查看>>
android:scaleType属性
查看>>
在Ubuntu上手动安装nginx软件
查看>>
Linux任务前后台的切换
查看>>
SpringBoot之第一个应用HelloWorld
查看>>
Thinkphp 数据的修改及删除操作
查看>>
hbase命令
查看>>
Java序列化和反序列化
查看>>
acm algorithm practice Dec. 27 MST
查看>>
LINQ系列:Linq to Object投影操作符
查看>>
微信公众号的文本回复(文本回复接口)
查看>>
CentOS7.X怎样更新yum源
查看>>
color theme
查看>>
vue 监听组件被重新渲染后的事件
查看>>
[Aaronyang] 写给自己的WPF4.5 笔记9[复杂数据处理三步曲,数据展示ListView泪奔2/3]...
查看>>
第十章 集成ISIS协议--10.1
查看>>
六、C# 派生
查看>>
SSH整合错误三连
查看>>
如何把彩色网页快速变为灰色网页?
查看>>