美文网首页js css html
2023.11 TS学习-接口

2023.11 TS学习-接口

作者: wo不是黄蓉 | 来源:发表于2023-02-28 21:46 被阅读0次

大家好,我是wo不是黄蓉,今年学习目标从源码共读开始,希望能跟着若川大佬学习源码的思路学到更多的东西。

发现文档上的一些描述竟然看不太懂...可能需要实际用的时候再琢磨琢磨,有的也没有想到很好的应用场景就不太好举例

ts学习

准备ts环境,npm i -g typescript

tsc --init初始化一个ts配置文件

tsc .\src\demo.tsdemo.ts编译为demo.js

接口


interface Person {
  firstName: string
  lastName: string
  //可选属性
  age?: number 
  //只读属性
  readonly sex: number
}

//数组创建后不能再被修改了
let ro: ReadonlyArray<number> = a;
额外的属性检查

传入不匹配的属性,会报错


interface Person {
  firstName: string
  lastName: string
}
function greeter(person: Person) {
  return "Hello, " + person.firstName + " " + person.lastName
}
//这段会提示报错,因为传参的属性name是不存在的
greeter({ name: "huang", lastName: "jane" })
函数类型

使用接口表示函数类型


interface PrintParam {
  (name: string): void
}

let printFun: PrintParam
printFun = function (name: string) {
  console.log(`my name is ${name}`)
}

printFun("piao")
可索引类型

使用Index访问时返回string类型的值,支持数字和字符串索引,数字索引的返回值必须是字符串索引返回值类型的子类型 (这句话不理解是什么意思?)

参考下面答案,因为doganimal的子类,所以使用数字类型索引不会报错

虽然是使用的数字作为索引的但是最终会转成字符串类型的索引,类似于for ... in 遍历数组


interface StringArray {
  [index: number]: string;
}

let myArray: StringArray;
myArray = ["Bob", "Fred"];

let myStr: string = myArray[0];

编译后的结果


var myArray
myArray = ["Bob", "Fred"]
var myStr = myArray[0]

name的类型与字符串索引类型不匹配,所以类型检查器给出一个错误提示(?)

是因为其他的属性返回值类型都返回的是number类型才报错的吗?


interface NumberDictionary {
  [index: string]: number;
  length: number;    // 可以,length是number类型
  name: string       // 错误,`name`的类型与索引类型返回值的类型不匹配
}

给索引设置只读


interface ReadonlyStringArray {
    readonly [index: number]: string;
}
let myArray: ReadonlyStringArray = ["Alice", "Bob"];
myArray[2] = "Mallory"; // error!
类类型
实现接口

用接口实现类的约束


interface Person {
  name: string
}

class Student implements Person {
    //报错,因为前面接口约束了参数类型是string类型
  name: number
  constructor(name: string) {
    this.name = name
  }
}

接口中定义函数,类中实现


interface Person {
  name: string
  printName(name: string): void
}

class Student implements Person {
  name: string
  constructor(name: string) {
    this.name = name
  }
  printName(name: string) {
    console.log(name)
  }
}
类静态部分和实例部分的区别

这一部分没太看懂???

类的两个类型:静态部分的类型和实例的类型

静态部分指的是,Student继承了Person接口,ts会对new出来的实例进行检查,而不是检查Student内部的构造函数参数

实例部分指的是,new出来的实例,,如果Student类有构造方法且对参数进行了约束,那么作为实例student1对其传参是有约束的


class Student{
    score:number
    constructor(score:number){
        this.score = score
    }
}
const student1 = new Student(99)
继承接口
interface Person {
  name: string
  age: number
}
interface Children {
  canSayHi: boolean
}
//学生继承person和children 继承多个对象用,隔开
interface Student extends Person, Children {
  isWork: boolean
}
混合类型

一个对象可以同时具有多种类型,这个也是看不太懂???

interface Counter {
    //定义多种类型
    (start: number): string;
    interval: number;
    reset(): void;
}
//Counter作为对象的参数约束使用
function getCounter(): Counter {
    //当作对象使用,counter作为类型约束
    let counter = <Counter>function (start: number) { };
    counter.interval = 123;
    counter.reset = function () { };
    return counter;
}

//当作函数使用
let c = getCounter();
c(10);
c.reset();
c.interval = 5.0;
接口继承类

//接口继承类
class Student {
  sayHi() {}
}
interface Person extends Student {}

//会编译报错,children实现了person,而person有继承了student,所以children必须实现student的sayHi方法
class Children implements Person {}
let children = new Children()
1677677947626.png

相关文章

  • 8、TypeScript 接口继承接口,类实现多接口

    1、ts类中只能继承一个父类2、ts类中可以实现多少接口,使用(,)号分隔3、ts接口中可以继承多个接口,使用(,...

  • TypeScript基础入门 - 接口 - 继承接口

    转载地址 TypeScript基础入门 - 接口 - 继承接口 项目实践仓库 为了保证后面的学习演示需要安装下ts...

  • TS学习笔记(二):接口

    在面向对象语言中,接口(Interfaces)是一个很重要的概念,它是对行为的抽象,而具体如何行动需要由类(cla...

  • TS接口

    函数和方法的区别: 当一个函数是对象的属性时,这个函数为该对象的方法 接口就是用代码描述一个对象必须有什么属性(包...

  • TS: 接口

    接口算是官方文档里的第一个知识点了,这篇文章会简单介绍 TypeScrip 里的接口。 类型 在说接口之前我们先来...

  • TS - 接口

    接口是对行为的抽象,由类来定义对象或函数的类型 初始化 tslint 配置规则 可选属性 A red tomato...

  • typeScript语法

    ts类型 ts联合类型使用或 ts定义任意类型any ts定义函数返回值的类型 ts中的类定义 interface接口

  • TypeScript基础知识

    命令 查看版本:tsc -v 运行ts文件:tsc xx.ts 数据类型 接口Interface 类和接口 泛型基...

  • TypeScript 学习笔记 之 接口与类

    接口 TS 中判断是否实现接口的核心原则是基于结构而不是基于名称的。即鸭子类型判断。 TS 中接口可以声明可选的接...

  • 【第7篇】TypeScript泛型的案例代码详解

    1、最简单泛型例子 Ts代码 Js文件 2、泛型类型与接口 Ts代码一 Ts编译js代码一 Ts代码二 Ts编译j...

网友评论

    本文标题:2023.11 TS学习-接口

    本文链接:https://www.haomeiwen.com/subject/mltrldtx.html