广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >typeScript 核心基础之接口interface
  • 133
分享到

typeScript 核心基础之接口interface

2024-04-02 19:04:59 133人浏览 八月长安
摘要

目录1、接口定义2、接口继承3、类实现接口前言: 在面向对象语言中,接口是一个很重要的概念,它是对行为的抽象。接口也叫 interface 。 在 js 中没有接口这个概念,它是新增

前言:

面向对象语言中,接口是一个很重要的概念,它是对行为的抽象。接口也叫 interface 。

js 中没有接口这个概念,它是新增的。该如何定义呢?下面来一起学习

1、接口定义

接口的作用:

  • 在面向对象编程中,接口是一种规范的定义,它定义了行为和动作规范;
  • 在程序设计内,接口起到一种限制和规范的作用;

接口一般使用 interface 关键字来定义,名字首字母需要大写。在项目中定义接口的时候,一般在名字前加一个大写 I 字母,能够快速识别该类型是接口。如:

interface IPerson{
 name: string
 age: number
 sex: string
}

接口的主要作用就是用来进行约束对象的规范,如:

interface IPerson{
 name: string
 age: number
 sex: string
}
let WEBPerson: IPerson = {
 name:"倩倩",
 age:18,
 sex:'girl'
}

使用上述 IPerson 定义对象的时候,上述三个属性都是必加的,如果漏掉一个就会有错误提示。那如果某些属性有些对象有,有些对象没有呢?比如职业。

接口成员也可以是缺省的,定义的时候使用 "?" ,如:

interface IPerson{
 name: string
 age: number
 sex: string
 work?: string
}

但是在特殊情况下,有些人有饮食忌讳,大多数没有,有些人有特殊爱好,大多数也没有,此时这个属性不能具体,此时就可以添加任意属性,使用 propName 来定义,如:

interface IPerson{
 name: string
 age: number
 sex: string
 work?: string
 [propName:string]: any
}
let webPerson: IPerson = {
 name:"倩倩",
 age:18,
 sex: 'girl',
 hobby: "跳舞",
 refuse:"不吃羊肉"
}

添加任意属性之后,可以添加任意多个特殊属性。

2、接口继承

接口和类一样,接口也可以相互继承。能够从一个接口里复制成员到另一个接口里,可以灵活地将接口分割到可重用的模块里面。继承的时候使用 extends 关键字。如:

interface IPerson{
 name: string
 age: number
 sex: string
 work?: string
 [propName:string]:any
}
interface IAdult extends IPerson{
 isHaveChildren: boolean
 isBoss: boolean
}
let Tom: IAdult = {
 isBoss: false,
 isHaveChildren: false,
 name: '倩倩',
 age: 20,
 sex: "girl"
}

一个接口可以继承一个或多个接口,多个接口之间使用逗号 "," 分割。如:

interface IPerson{
 name: string
 age: number
 sex: string
}
interface IAdult extends IPerson{
 isBoss: boolean
}
interface elderly extends IPerson, IAdult{
 isRetire:boolean 
}

接口的继承也就是接口的扩展,接口扩展就是多添加了一些约束,一个接口可以扩展多个接口。

3、类实现接口

typescript 中,接口可以继承类,这样接口就具有了类的所有成员,同时这个接口只能引用这个类或者它的字类的实例。如:

class Person{
 name:string;
 age: number
 constructor(name: string, age: number) {
  this.name = name
  this.age = age
 }
}
interface IAdult extends Person{
 married:boolean
}
let Tom: IAdult = {
 name: "Tom",
 age: 20,
 married: true
}
console.log(Tom);

接口继承一个类类型时,它会继承类的成员但不包括其实现。

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

--结束END--

本文标题: typeScript 核心基础之接口interface

本文链接: https://www.lsjlt.com/news/140092.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • typeScript 核心基础之接口interface
    目录1、接口定义2、接口继承3、类实现接口前言: 在面向对象语言中,接口是一个很重要的概念,它是对行为的抽象。接口也叫 interface 。 在 js 中没有接口这个概念,它是新增...
    99+
    2022-11-13
  • js核心基础之闭包怎么用
    这篇文章主要介绍了js核心基础之闭包怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体如下:需求:有一个列表,当点击哪一行,则显示当前...
    99+
    2022-10-19
  • Java基础之Spring5的核心之一IOC容器
    目录一、什么是IOC二、IOC的底层原理三、IOC思想四、Spring 提供IOC容器实现两种方式:(两个接口)五、IOC操作之Bean管理一、什么是IOC 1)控制反转,把创建对象...
    99+
    2022-11-12
  • java基础教程之接口
    定义:接口就是多个类的共有规范(里面的抽象方法),是一种引用数据类型。小提示:基本数据类型包括数值型(整数和浮点数)、字符型、布尔型。格式:public interface 接口名称{ //接口内容 }备注:接口.java编译后仍然是接口...
    99+
    2019-04-11
    java入门 java 接口
  • 《Java 基础篇》之函数式接口
    目录 1、函数式接口概述 2、函数式接口做为方法的参数 3、函数式接口作为方法的返回值 3、常用的函数式接口 3.1、Supplier [səˈplaɪə(r)] Supplier接口 3.2、Consumer接口 3.3、Predicat...
    99+
    2023-10-20
    java 开发语言
  • Java基础学习之接口详解
    目录概述定义格式含有抽象方法含有默认方法和静态方法含有私有方法和私有静态方法基本的实现实现的概述抽象方法的使用默认方法的使用静态方法的使用私有方法的使用接口的多实现抽象方法默认方法静...
    99+
    2022-11-13
    Java接口使用 Java接口
  • Kotlin 基础教程之类、对象、接口
    Kotlin 基础教程之类、对象、接口Kotlin中类、接口相关概念与Java一样,包括类名、属性、方法、继承等,如下示例:interface A { fun bar() fun foo() { // 可选方法体 }}class C...
    99+
    2023-05-31
    kotlin 对象
  • Java入门基础之抽象类与接口
    目录一.抽象类1.什么是抽象类2.语法规则3.抽象类的作用二.接口1.什么是接口2.语法规则3.实现多个接口4.接口之间的继承三.接口的使用实例1. Comparable 接口2.C...
    99+
    2022-11-13
  • etcd通信接口之客户端API核心方法实战
    目录前言etcd clientv3 客户端etcd 客户端初始化client 定义前言 我们在前面介绍了 etcd 的整体架构。学习客户端与 etcd 服务端的通信以及 etcd 集...
    99+
    2022-11-13
  • java基础之接口组成更新的实现
    目录1.1 接口组成更新概述1.2 接口中默认方法(JDK8)1.3 接口中静态方法(JDK8)1.4 接口中私有方法(JDK9)1.1 接口组成更新概述 接口的组成 常量:publ...
    99+
    2022-11-13
  • etcd通信接口之客户端API核心方法怎么使用
    本篇内容介绍了“etcd通信接口之客户端API核心方法怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!etcd clientv3 客户...
    99+
    2023-07-02
  • Go基础教程系列之Go接口使用详解
    接口用法简介 接口(interface)是一种类型,用来定义行为(方法)。 type Namer interface { my_method1() my_method...
    99+
    2022-11-13
  • Java面向对象基础知识之抽象类和接口
    抽象类(abstract): 抽象类不能创建实例,它只能作为父类被继承。抽象类是从多个具体类中抽象出来的父类,它具有更高层次的抽象。从多个具有相同特征的类中抽象出一个抽象类,以这个抽...
    99+
    2022-11-12
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作