【TypeScript】class类型讲解

生活中,最使人疲惫的往往不是道路的遥远,而是心中的郁闷;最使人痛苦的往往不是生活的不幸,而是希望的破灭;最使人颓废的往往不是前途的坎坷,而是自信的丧失;最使人绝望的往往不是挫折的打击,而是心灵的死亡。所以我们要有自己的梦想,让梦想的星光指引着我们走出落漠,走出惆怅,带着我们走进自己的理想。

导读:本篇文章讲解 【TypeScript】class类型讲解,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

目录

class类型

构造函数

class类的继承

可见修饰符

只读修饰符


class类型

TypeScript支持ES引入的class关键字,并为其添加了类型注解和其他语法(例如:可见性修饰符)。

class person {
  // 声明初始值,可省略类型注解(TS类型推论为string)
  name:'张三'
  // 声明成员类型为 number 没有初始值
  age: number
}
const p = new person()
p.name
p.age

构造函数

在class构造函数中,需要为构造函数指定类型注解,否则会被隐式推断为any,构造函数不需要返回值类型。

class Person {
  name:string
  age:number
  constructor(name:string,age:number){
    this.name = name
    this.age = age 
  }
}
const p = new Person('张三',18)

在class的实例方法中,方法的类型注解(参数与返回值)与函数用法相同。

class Point {
  x=1
  y=2
  scale(n: number){
    this.x*=n
    this.y*=n
  }
}
const p = new Point()
p.scale(5)
console.log(p.x,p.y);// 5 10

class类的继承

在class类的继承中,提供了两种类的继承方式:1、extends(继承父类)  2、implements(实现接口)。注意:JS中只有extends,而implements是TS提供的。

class Animal {
  move(){
    console.log('我是动物');
  }
}
// 使用 extends 继承父类
class Dog extends Animal {
  name='狗'
  say(){
    console.log('我是狗');
  }
}
const p = new Dog()
p.move()// 我是动物
p.say()// 我是狗
console.log(p.name);// 狗
interface Animals {
  name: string
  say(): void
}
// Dog类继承接口Animals,意味着Dog类必须提供Animals接口中指定的所有方法和属性
class Dog implements Animals {
  name = 'hobble'
  say(): void {
    console.log('汪汪汪');
  }
}

可见修饰符

在class中,类的可见性可以使用TS来控制class的方法或属性对于class外的代码是否可见。可见性修饰符包括:public(公有的)、protected(受保护的)、private(私有的)。

class Animal1 {
  // 因为 public 是默认可见的,所以可以直接忽略
  public move(){
    console.log('我是动物');
  }
}
class Dog1 extends Animal1 {}
const p1 = new Dog1()
p1.move()// 我是动物


class Animal2 {
  // 仅对其声明的所在类和子类中(非实例对象)可见
  protected move(){
    console.log('我是动物');
  }
  run(){
    this.move
  }
}
class Dog2 extends Animal2 {
  say(){
    this.move
  }
}
const p2 = new Dog2()
// p.move() 报错


class Animal3 {
  // private表示私有的,只在当前类中可见,对实例对象以及子类是不可见的
  private move(){
    console.log('我是动物');
  }
  run(){
    this.move
  }
}
class Dog3 extends Animal3 {
  say(){
    // this.move 报错
  }
}

只读修饰符

除了可见修饰符之外,还有一个常见的修饰符就是:readonly(只读修饰符)。readonly:表示只读,用来防止在构造函数之外对属性进行赋值。

 class Person {
  // 注意:只要是readonly来修饰的属性,必须手动提供明确属性,否则就是字面量类型
  readonly age: number = 18
  constructor(age: number){
    this.age = age
  }
  setAge(){
    // 无法分配到 "age" ,因为它是只读属性。
    // this.age = 20 
  }
 }

注意:readonly只能修饰属性不能修饰方法。

【TypeScript】class类型讲解

在接口和{}表示的对象类型中,也可以使用 readonly 。

// 在接口中
interface People {
  readonly name: string
}

let obj: People = {
  name:'张三'
}
// obj.name = '李四' 报错

// 在对象中
let oj: { readonly name: string } = {
  name:'张三'
}
// oj.name = '李四' 报错

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/140021.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!