类的修饰器

作者: tiancai啊呆 | 来源:发表于2018-05-19 19:53 被阅读11次

是什么

修饰器是一个对类进行处理的函数。修饰器不仅可以修饰类,还可以修饰类的属性,但是修饰器不能用于函数。

怎么用

  • 修饰类
    当修饰类时:修饰器函数的第一个参数,就是所要修饰的目标类。
      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不可写,只读。
    
  • 修饰器可以叠加使用,像剥洋葱一样,先从外到内进入,然后由内向外执行。(类似于栈,先进后出)

参考

相关文章

  • 类的修饰器

    是什么 修饰器是一个对类进行处理的函数。修饰器不仅可以修饰类,还可以修饰类的属性,但是修饰器不能用于函数。 怎么用...

  • ES6_修饰器

    修饰器@ 只能用于类 和 类的方法 类的修饰器 修饰器对类的行为的改变,是代码编译时发生的,而不是在运行时 方法的...

  • es6 修饰器

    写在前面,因为function存在变量提升,所以修饰器是只能修饰类,而不能修饰函数 修饰器是一个函数,用来修改类的...

  • es6学习笔记整理(十六)Decorators

    Decorator修饰器 修饰器是一个函数用来修改类的行为: 1、修饰器是一个函数 2、修改行为 3、修改类的行为...

  • 2018-02-05 阮一峰教程摘记16 Decorator(修

    1.类的修饰 修饰器函数--用来修改类的行为------提案 2.方法的修饰 --修饰类的属性(方法) 3.为什么...

  • SSM控制器的注解

    1.基于注解的控制器:常用的控制器注解: 1.1@Controller使用方式:修饰于类上面修饰控制器类:表明是一...

  • JavaScript(ES6) - Decorator

    类的修饰 修饰器(Decorator)是一个函数,用来修改类的行为。这是ES7的一个提案,目前Babel转码器已经...

  • 27- ES6 装饰器

    1、类的修饰 decorator(target) {} 许多面向对象的语言都有修饰器(Decorator)函数,...

  • abstract关键字

    abstract:抽象的,可以用来修饰类、方法1.abstract修饰类:抽象类1)不可被实例化2)抽象类有构造器...

  • 第二十一章 修饰器

    类的修饰   修饰器是一个函数,用来修改类的行为。ES7引入了这个功能,目前Babel转码器已经支持。   上面代...

网友评论

    本文标题:类的修饰器

    本文链接:https://www.haomeiwen.com/subject/mveekftx.html