设为首页 加入收藏

TOP

ES6-----学习系列十七(Decorator)
2017-10-13 10:49:45 】 浏览:3088
Tags:ES6----- 学习 系列 十七 Decorator

Decorator就是修饰器的意思

 一、概念

  修饰器是一个函数,用来修改类的行为(注意:1、函数  2、修改行为  3、对类进行操作)

  1、只读的修饰器

{
  let readonly=function(target,name,descriptor){
    descriptor.writable=false;
    return descriptor
  };

  class Test{
    @readonly
    time(){
      return '2017-03-11'
    }
  }

  let test=new Test();

  // test.time=function(){
  //   console.log('reset time');
  // }; 将报错  如果修改的话

  console.log(test.time());
}

  也可以在类的前面进行修饰

{
  let typename=function(target,name,descriptor){
    target.myname='hello';
  }

  @typename
  class Test{

  }

  console.log('类修饰符',Test.myname);//hello
  // 第三方库修饰器的js库:core-decorators; npm install core-decorators
}

  

{
  let log=(type)=>{
    return function(target,name,descriptor){
      let src_method=descriptor.value;
      descriptor.value=(...arg)=>{
        src_method.apply(target,arg);
        console.info(`log ${type}`);
      }
    }
  }

  class AD{
    @log('show')
    show(){
      console.info('ad is show')
    }
    @log('click')
    click(){
      console.info('ad is click');
    }
  }

  let ad=new AD();
  ad.show();
  ad.click();
}

 

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
上一篇javascript运动框架(二) 下一篇ES6-----学习系列十五(Iterator)

最新文章

热门文章

Hot 文章

Python

C 语言

C++基础

大数据基础

linux编程基础

C/C++面试题目