【十月打卡】第62天 TypeScript(18)
标签:
Typescript
类的方法修饰器
方法修饰器的用法
参数:
- target:当前方法所在的对象
- key:当前方法的名称
- descriptor:当前方法的描述符
原型上的方法的target就是原型
function getNameDecoration(target: any, key: string, descriptor: any) {
console.log(target === Test.prototype); // true
}
class Test {
constructor(private name: string) {}
@getNameDecoration
getName() {
return this.name;
}
}
类的方法的target就是类本身
function getNameDecoration(target: any, key: string, descriptor: any) {
console.log(target === Test); // true
}
class Test {
constructor(private name: string) {}
@getNameDecoration
static getName() {
return this.name;
}
}
属性描述符descriptor
descriptor.value
可以修改属性的值
function getNameDecoration(target: any, key: string, descriptor: any) {
descriptor.value = () => {
return 'abc';
};
}
class Test {
constructor(private name: string) {}
@getNameDecoration
getName() {
return this.name;
}
}
const test = new Test('hello');
console.log(test.getName()); // abc
如果装饰器属性描述符descriptor.writable = false;
那么该属性可读不可写
如下类的原型和实例都不可以重写方法
function getNameDecoration(target: any, key: string, descriptor: any) {
descriptor.writable = false;
}
class Test {
constructor(private name: string) {}
@getNameDecoration
getName() {
return this.name;
}
}
const test = new Test('hello');
test.getName = () => {
return '123';
};
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦