TS3——类
Posted 勇敢*牛牛
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了TS3——类相关的知识,希望对你有一定的参考价值。
当前的文件为一个模块,它相当于有了作用域
export
ts中定义一个类,使用class关键字来完成
定义的类,它也可以当前一个类型来使用
ts中定义的类,它有类的修饰符
如果你定义的方法或属性没有指修饰符,则默认为public
public 公有的 定义的方法或属性在本类或子类或实例中都可以操作
protected 受保护的 定义的方法或属性只能在本类或子类中操作
private 私有的 定久的方法或属性只能在本类中操作
readonly 定义后,当前的属性它就为只读,不可修改
static 定义的属性为静态属性,定义的方法为静态方法,静态方法中不能使用this
访问器和修改器 getter/setter
标准写法
class Person
// 定义属性
public name: string
// 属性进行初始化
constructor(name: string)
this.name = name
定义的类,它也可以当前一个类型来使用
class Person
// 定义属性
public name: string
// 属性进行初始化
constructor(name: string)
this.name = name
let p:Person = new Person("niuniiu")
console.log(p.name);
=========简写
class Person
constructor(public name:string)
let p1:Person = new Person("牛牛")
console.log(p1);
typescript属性的封装时,用到set方法和get方法时的错误提示:
Accessors are only available when targeting ECMAScript 5 and higher.
大概就是说:访问器仅在针对ECMAScript 5及更高版本时可用。
可以通过命令指定:
tsc xxx.ts -t es5
class Person
constructor( public _name:string)
get name()
return this._name+"@@@"
set name(name:string)
this._name = name
let p1:Person = new Person("牛牛")
console.log(p1.name)
p1.name="niuniu";
console.log(p1.name)
类的封装性
class Person
constructor(private _name:string)
/* 类的封装性 */
private print(str:string)
console.log(str);
;
say(str:string)
this.print(str)
let p1:Person = new Person("牛牛")
console.log(p1.name)
p1.name="niuniu";
console.log(p1.name)
p1.say("不怕困难")
以上是关于TS3——类的主要内容,如果未能解决你的问题,请参考以下文章