经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » TypeScript » 查看文章
TypeScript接口介绍
来源:jb51  时间:2021/12/9 18:02:23  对本文有异议

前言:

TS的核心原则之一就是对所具有的结构 进行类型检查。接口的作用就是为这些类型命名和为你的代码或第三方代码定义契约。

最终被编译成JavaScript代码后不包含接口以及类型约束的代码。

1.接口的定义

接口的作用于type关键字类似,但是又不一样。type可以定义简单的数据类型,例如如下代码

  1. type str = string
  2.  
  3.  

这种写法就不能应用在 接口 中,接口中只能写函数类型和类类型还有数组类型。

在TS中定义接口使用interface关键字。

示例代码如下所示:

  1. // 定义一个简单的接口
  2. interface Person {
  3. name: string
  4. }
  5. // 定义 get 方法
  6. function getPersonName(person: Person): void {
  7. console.log(person.name)
  8. }
  9. // 定义 set 方法
  10. function setPersonName(person: Person, name: string): void {
  11. person.name = name
  12. }
  13. // 定义一个 person 对象
  14. let person = {
  15. name: '一碗粥',
  16. }
  17. setPersonName(person, '一碗周')
  18. // 修改成功
  19. getPersonName(person) // 一碗周
  20.  

Person 接口就像是一个名字,它用来描述使用该接口中的要求,例如此接口中需要一个name属性,且类型为string类型。

值得注意的是,类型检查并不会检查属性的顺序,只需要对应你的属性存在,且类型相同即可。

2.属性

2.1可选属性

如果接口中的某个属性是可选的,或者说仅仅在某个条件下存在,可以在属性名旁边加一个?号。示例代码如下:

  1. ;(function () {
  2. // 定义一个简单的接口
  3. interface Person {
  4. name: string
  5. // 说明 age 是可选的
  6. age?: number
  7. }
  8. // 定义一个 person 对象
  9. let person = {
  10. name: '一碗周',
  11. age: 18,
  12. hobby: 'coding',
  13. }
  14. // 定义 get 方法
  15. function getPersonName(person: Person): void {
  16. // console.log(person.age, person.hobby) // Property 'hobby' does not exist on type 'Person'.
  17. }
  18. })()
  19.  

此时的sex属性我们可写可不写,但是hobb 属性,由于没有在接口中定义,我们调用会抛出异常。

2.2只读属性

如果想让一个属性为一个只读属性,仅仅需要在属性前面添加readonly即可。

示例代码如下:

  1. ;(function () {
  2. interface Person {
  3. // 将 name 设置为只读
  4. readonly name: string
  5. }
  6. // 定义一个 person 对象
  7. let person = {
  8. name: '一碗周',
  9. }
  10. // 定义 set 方法
  11. function setPersonName(person: Person, name: string): void {
  12. person.name = name // Cannot assign to 'name' because it is a read-only property.
  13. }
  14. setPersonName(person, '一碗粥')
  15. })()
  16.  

3.类类型

3.1继承接口

和类一样,接口也可以相互继承。 这让我们能够从一个接口里复制成员到另一个接口里,可以更灵活地将接口分割到可重用的模块里。

接口继承使用extends关键字,示例代码如下:

  1. // 定义两个接口
  2. interface PersonName {
  3. name: string
  4. }
  5. interface PersonAge {
  6. age: number
  7. }
  8.  
  9. // 定义一个 Person 接口继承于以上两个接口 多个接口使用 , 逗号分割
  10. interface Person extends PersonName, PersonAge {
  11. hobby: string
  12. // 定义一个方法,返回值为 string
  13. say(): string
  14. }
  15. let person = {
  16. name: '一碗周',
  17. age: 18,
  18. hobby: 'coding',
  19. // 示例方法
  20. say() {
  21. return '一碗周'
  22. },
  23. }
  24. // 定义 get 方法
  25. function getPersonName(person: Person): void {
  26. console.log(person.name, person.age, person.hobby)
  27. }
  28. getPersonName(person) // 一碗周 18 coding
  29.  

继承多个接口中间使用,逗号分割。

4.函数类型

在TS中接口还可以对函数类型的接口进行描述。

函数类型接口的定义就像是一个只有参数列表和返回值类型的函数定义,参数列表中每个参数都需要名字和类型 。

示例代码如下所示:

  1. interface MyAdd {
  2. (x: number, y: number): number
  3. }
  4.  
  5.  

定义完成之后我们可以像使用普通接口一样使用这个函数接口。

示例代码如下所示:

  1. let myAdd: MyAdd = (x: number, y: number): number => {
  2. return x + y
  3. }
  4.  
  5.  

上面的代码等同于如下函数定义的代码:

  1. let myAdd: (x: number, y: number) => number = (
  2. x: number,
  3. y: number
  4. ): number => {
  5. return x + y
  6. }

到此这篇关于TypeScript接口介绍的文章就介绍到这了,更多相关TypeScript接口 内容请搜索w3xue以前的文章或继续浏览下面的相关文章希望大家以后多多支持w3xue!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号