一、 public
public修饰属性可以是属性在任意位置访问(修改)默认值
class Person {
// public修饰属性可以是属性在任意位置访问(修改)默认值
public _name:string;
constructor(name:string){
this._name=name;
}
}
let per=new Person("ts");
console.log(per);
console.log(per._name);
per._name="js";
console.log(per._name);
二、private
private私有属性,只能在类的内部进行访问(修改),但是可以在类中添加方法是私有属性可以在外被访问
class Person {
// private私有属性,只能在类的内部进行访问(修改),但是可以在类中添加方法是私有属性可以在外被访问
private _name:string;
constructor(name:string){
this._name=name;
}
}
let per=new Person("ts");
console.log(per);
console.log(per._name);//报错
per._name="js";//报错
console.log(per._name);//报错
会因为无法外部访问修改而报错。
但是可以在类中定义方法是私有属性可以外部访问修改,即setter,getter方法。
class Person {
// private私有属性,只能在类的内部进行访问(修改),但是可以在类中添加方法是私有属性可以在外被访问
private _name:string;
constructor(name:string){
this._name=name;
}
setName(name:string){
this._name=name;
}
getName(){
return this._name;
}
}
let per=new Person("ts");
console.log(per);
console.log(per.getName())
per.setName("js")
console.log(per.getName())
当然TS里有自带的setter,getter方法,可以让操作过程请倾向于属性
class Person {
// private私有属性,只能在类的内部进行访问(修改),但是可以在类中添加方法是私有属性可以在外被访问
private _name:string;
constructor(name:string){
this._name=name;
}
get name():string{
return this._name;
}
set name(name:string){
this._name=name;
}
}
let per=new Person("ts");
console.log(per);
console.log(per.name);
per.name="js";
console.log(per.name);
三、protected
受继承的影响只能在类本身或者子类中访问和修改
class Man{
protected name:string;
constructor(name:string){
this.name=name;
}
out(){
console.log(this.name)
}
}
let m=new Man("ds");
m.out();
class Min extends Man{
}
let min=new Min("min");
min.out();
console.log(m.name);//报错
console.log(min.name);//报错
四、constructor简易写法
constructor(public name:string){
}
相当于
public name:string;
constructor(name:string){
this.name=name;
}