1.修饰符
ts里面定义属性的时候给我们提供了三种修饰符:
-
public: 共有类型,在当前类里面、子类、类外部都可以访问
-
private: 私有类型,在当前类里面可以访问,子类、类外部不能访问
-
protected: 保护类型,在当前类里面、子类可以访问,类外部不能访问
注:属性如果没有显示声明修饰符,则默认为 public
2.定义
使用 class 关键字定义类。
// 定义 Person 类
class Person {
name: string; // 属性,前面省略了 public 修饰符
// public name: string; // 等同于上一行效果
// 构造函数,实例化类的时候触发
constructor(name: string) {
this.name = name;
}
getName(): string {
return this.name;
}
setName(name:string): void {
this.name = name;
}
}
var p = new Person('张三');
console.log( p.getName() ); // 张三
p.setName('李四');
console.log( p.getName() ); // 李四
3.静态属性 & 静态方法
通过 static 关键字声明静态属性 & 静态方法,通过 类名.属性名 或者 类名.方法名 直接调用。
class Person {
public name: string;
public age: number = 20;
// 静态属性
static sex = '男';
constructor(name