我的编程空间,编程开发者的网络收藏夹
学习永远不晚

TypeScript接口使用介绍

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

TypeScript接口使用介绍

1 概述

接口是一种规范的定义,它定义了行为和动作的规范;在程序设计里面,接口起到一种限制和规范的作用。接口定义了某一批类所需要遵守的规范,接口不关心这些类的内部状态数据,也不关心这些类里方法的实现细节,它只规定这批类里必须提供某些方法,提供这些方法的类就可以满足实际需要。

接口使用interface关键字来进行定义。

2 接口类别

2.1 属性接口

属性接口对传入的对象进行约束。

interface 接口名 {
    属性1: 类型;
    属性2: 类型;
}

示例代码:

interface IPeople {
    name: string;
    age: number;
}
// 为函数的参数使用接口
function people(person: IPeople) {
    console.log("姓名:", person.name);
    console.log("年龄:", person.age);
}
people({ name: "橘猫吃不胖", age: 2 }); // 姓名: 橘猫吃不胖  年龄: 2
people("123"); // 报错,参数类型与接口内容不符合
people({ name: "橘猫吃不胖" }); // 报错,参数缺少age
people({ name: "橘猫吃不胖", age: 2, sex: "女" }); // 报错,参数增加了sex

2.2 可选接口

在接口的属性名后面加一个“?”,表示这个接口是可选的。

interface 接口名 {
    属性1?: 类型;
    属性2?: 类型;
}

示例代码:

interface IPeople {
    name: string;
    age?: number; // 表示age是可选属性,有无都可以
}
// 为函数的参数使用接口
function people(person: IPeople) {
    console.log("姓名:", person.name);
    console.log("年龄:", person.age);
}
people({ name: "橘猫吃不胖", age: 2 }); // 姓名: 橘猫吃不胖  年龄: 2
people({ name: "橘猫吃不胖" }); // 姓名: 橘猫吃不胖  年龄: undefined
people({ name: "橘猫吃不胖", age: 2, sex: "女" }); // 报错,属性增加了sex

2.3 函数类型接口

函数类型接口可以对对方法传入的参数以及返回值进行约束。

interface 接口名 {
    (参数1: 类型, 参数2: 类型): 类型;
}

示例代码:

interface Obj { // 定义接口Obj
    (key: string, value: number): string;
}
var myFun: Obj = function (key: string, value: number): string {
    return key + ":" + value;
}
console.log(myFun("橘猫吃不胖", 2)); // 橘猫吃不胖:2

2.4 可索引接口

可索引接口主要用于对数组和对象的约束(不常用)。

interface 接口名 {
    [索引: 类型]: 类型;
}

示例代码:对数组的约束

// 对数组的约束
interface Arr {
    // 字符串类型的数组,数组索引为string类型
    [index: number]: string;
}
var arr1: Arr = ["1", "2", "3"]; // 格式正确
var arr2: Arr = [1, 2, 3]; // 报错

示例代码:对对象的约束

// 对对象的约束
interface Obj {
    // 索引是字符串型
    [index: string]: string;
}
var obj1: Obj = { "张三": "zhangsan", "李四": "lisi" }; // 格式正确
var obj2: Obj = { "张三": 12, "李四": 13 }; // 报错,值不是字符串型
var obj3: Obj = []; // 报错,索引是数字类型

2.5 类类型接口

类类型接口用于对类的属性以及方法进行约束,使用implements关键字对接口进行使用。在类中必须将接口中定义的属性和方法进行实现,否则会报错,并且类可以添加接口定义的之外的方法。

interface 接口名 {
    属性: 类型;
    方法: 类型;
}

示例代码:

interface IAnimal {
    name: string; // 定义name属性
    eat(): void; // 定义eat方法
}
class Dog implements IAnimal {
    name: string;
    constructor(name: string) {
        this.name = name;
    }
    eat(): void { // 实现eat方法
        console.log("吃骨头");
    }
}

如果不实现eat方法,代码会报错:

如果多增添一个sleep方法,代码不会报错:

3 接口继承

接口继承就是说接口可以通过其他接口来扩展自己。TypeScript 允许接口继承多个接口。继承使用关键字extends

1 单接口继承语法格式

interface 子接口 extends 父接口 {
    // 具体实现
}

示例代码:

interface Shape {
    color: string;
}
interface Square extends Shape {
    sideLength: number;
}
var s = <Square>{}; // 使用接口
s.color = "red";
s.sideLength = 30;
console.log(s); // { color: 'red', sideLength: 30 }

2 多接口继承语法格式

interface 子接口 extends 父接口1, 父接口2... {
    // 具体实现
}

示例代码:

interface Shape {
    color: string;
}
interface PenStroke {
    penWidth: number;
}
interface Square extends Shape, PenStroke {
    sideLength: number;
}
let s1 = <Square>{};
s1.color = "red";
s1.penWidth = 20;
s1.sideLength = 2;
console.log(s1); // { color: 'red', penWidth: 20, sideLength: 2 }

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

TypeScript接口使用介绍

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

TypeScript接口使用介绍

接口是一系列抽象方法的声明,是一些方法特征的集合,这些方法都应该是抽象的,需要由具体的类去实现,然后第三方就可以通过这组抽象方法调用,让具体的类执行具体的方法
2022-11-13

TypeScript中asconst使用介绍

这篇文章主要为大家介绍了TypeScript中asconst使用介绍,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-12-28

TypeScript泛型使用详细介绍

泛型是静态类型语言的基本特征,允许将类型作为参数传递给另一个类型、函数、或者其他结构。TypeScript支持泛型作为将类型安全引入组件的一种方式。这些组件接受参数和返回值,其类型将是不确定的,直到它在代码中被使用
2022-11-13

TypeScript接口怎么使用

这篇文章主要讲解了“TypeScript接口怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“TypeScript接口怎么使用”吧!前言:TS的核心原则之一就是对所具有的结构 进行类型检
2023-06-22

Android中回调接口的使用介绍

MainActivity如下: 代码如下: package cn.testcallback; import android.os.Bundle; import android.widget.Toast; import android.ap
2022-06-06

Java接口的介绍和用法

这篇文章主要介绍“Java接口的介绍和用法”,在日常操作中,相信很多人在Java接口的介绍和用法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java接口的介绍和用法”的疑惑有所帮助!接下来,请跟着小编一起来
2023-06-20

基于Android AIDL进程间通信接口使用介绍

AIDL:Android Interface Definition Language,它是一种android内部进程通信接口的描述语言,通过它我们可以定义进程间的通信接口。 ICP:Interprocess Communication ,内
2022-06-06

typeScript的interface接口怎么定义使用

这篇“typeScript的interface接口怎么定义使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“typeScri
2023-06-29

SpringApplicationContext接口功能详细介绍

ApplicationContext是Spring应用程序中的中央接口,由于继承了多个组件,使得ApplicationContext拥有了许多Spring的核心功能,如获取bean组件,注册监听事件,加载资源文件等
2023-02-06

编程热搜

目录