类的修饰器
标签:
JavaScript
是什么
修饰器是一个对类进行处理的函数。修饰器不仅可以修饰类,还可以修饰类的属性,但是修饰器不能用于函数。
怎么用
修饰类
当修饰类时:修饰器函数的第一个参数,就是所要修饰的目标类。function action(target) { target.prototype.eat = function () { //eat 会作为类的实例的属性 console.log('person can eat food') } target.sleep = function () { //sleep会作为类的静态属性,用类名直接调用。 console.log('person can sleep') } } @action //action 为修饰器 class Person { constructor(fullname, age) { this.fullname = fullname; this.age = age; } toString() { console.log(this.fullname + '---' + this.age); } } var p1 = new Person('xxx', 25); p1.toString(); //xxx---25 p1.eat() //person can eat food Person.sleep() //person can sleep
修饰类的属性
当修饰类的属性时:修饰器函数的第一个参数,是所要修饰的目标类的原型对象,第二个参数是所要修饰的属性名,第三个参数是该属性的描述对象。function readOnly(target, sex, descriptor) { descriptor.writable = false; return descriptor } class Person { constructor(fullname, age) { this.fullname = fullname; this.age = age; } toString() { console.log(this.fullname + '---' + this.age); } @readOnly sex = 'men' } var p1 = new Person('xxx', 25); p1.toString(); //xxx---25 console.log(p1.sex) //men p1.sex = 'women' console.log(p1.sex) //men //我们用readOnly来修饰sex属性,从而实现sex不可写,只读。
修饰器可以叠加使用,像剥洋葱一样,先从外到内进入,然后由内向外执行。(类似于栈,先进后出)
作者:tiancai啊呆
链接:https://www.jianshu.com/p/e36e94c8dd21
点击查看更多内容
为 TA 点赞
评论
共同学习,写下你的评论
评论加载中...
作者其他优质文章
正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦