typescript中的interface理解

typescript中的interface理解

1.简单理解interface

interface是一种自定义的类型检测规范

可以通过定义interface来作为对象型参数的类型检测

比如定义一个User类型的检测规范

typescript 复制代码
interface User{
  name:string,
  age:number,
  email?:string//?将email标记为可选属性
}

在使用User进行类型检测的时候

必须传入满足User的对象属性

typescript 复制代码
//比如下面这个函数,返回值必须得符合User的规范
//说明返回的对象必须为{name:"",age:0}或者{name:"",age:0,email:""}这样的类型
function setUser(usename:string,age:number,email?:string):User{
  return { name: username, age, email}
}

输出

typescript 复制代码
console.log(setUser("测试name",age:12))
//{ name: '测试name', age: 12, email: undefined }

2.interface的拓展

可以通过extends来在interface中加入其他interface的规范

typescript 复制代码
interface A{
  nameA:string
}
interface B{
  nameB:string
}
interface C extends A,B{
  nameC:string
}

此时interface c extends a,b{ nameC:string }就相当于

typescript 复制代码
interface C{
  nameA:string,
  nameB:string,
  nameC:string
}

使用C来进行检测时就得按照interface C 的规范

typescript 复制代码
const obj:C = {
  nameA:"这是A",
  nameB:"这是B",
  nameC:"这是C"
}
console.log(obj)
//{ nameA: '这是A', nameB: '这是B', nameC: '这是C' }

3.接口的实现类

用类来实现interface的时候,使用关键字implements来实现

需要把interface作为类最小实现规范,也就是类至少必须要实现interface的内容

类在满足interface的情况下也可以加其他的内容

下面的IUser接口,实现类至少需要实现getName()getAge(),才满足接口的规范

typescript 复制代码
interface IUser{
  getName():string,
  getAge():number
}

定义实现类AdminUser

typescript 复制代码
class AdminUser implements IUser{  
   private name:string
   private age:number
   constructor(adminName:string,adminAge:number){
    this.name=adminName
    this.age=adminAge
   }
   getName():string{//这个方法必须要有,且满足IUser的规范
    return this.name
   }
   getAge(): number {//这个方法必须要有,且满足IUser的规范
     return this.age
   }
   setName(newName:string):void{
    this.name = newName
   }
}

用类创建对象

typescript 复制代码
const admin = new AdminUser("管理员A",12)
admin.setName("管理员newName")
console.log(admin.getName())
// 管理员newName

补充

1.多态:一个类可以实现多个接口,一个接口也可以拓展多个接口的规范

2.索引签名: 只规范接口中属性的类型,不规范属性的名字时候

typescript 复制代码
interface testIndex {
  [key:string]: string; // 属性名为字符串,属性值也为字符串,但是不强制要求具体的属性名
}
const obj:testIndex={
  myKey:"这是我的Key"
}
console.log(obj)
// { myKey: '这是我的Key' }
相关推荐
小彭努力中7 分钟前
58.在 Vue 3 中使用 OpenLayers 绘制点、线、圆、多边形
前端·javascript·vue.js·arcgis·ecmascript·openlayers
小曲曲8 分钟前
可缩放大屏布局方式
前端
手撕代码21 分钟前
了解什么是JavaEE(什么是JavaEE)
java·前端·java-ee
失眠的咕噜22 分钟前
el-table 使用el-form 表单验证
前端·javascript·vue.js
古怪今人28 分钟前
Vue页面开发和脚手架开发 Vue2集成ElementUI Vue3集成Element Plus
前端·vue.js·elementui
itzixiao33 分钟前
使用npm 插件[mmdc]将.mmd时序图转换为图片
前端·npm·node.js
安girl33 分钟前
运行vue项目,显示“npm”无法识别为 cmdlet、函数、脚本文件或可操作程序的名称
前端·javascript·vue.js
还这么多错误?!34 分钟前
使用vue项目中,使用webpack模板和直接用vue.config来配置相关插件 区别是什么,具体有哪些提现呢
前端·vue.js·webpack
theMuseCatcher2 小时前
Vue Amazing UI 组件库(Vue3+TypeScript+Vite 等最新技术栈开发)
ui·typescript·vue3·vite·components
幽络源小助理2 小时前
HTML5 + Bootstrap5 网站底部代码分享与解析
前端·html·html5·网站底部代码