Heim >Web-Frontend >js-Tutorial >Detaillierte Einführung in Decorator in ES6

Detaillierte Einführung in Decorator in ES6

零下一度
零下一度Original
2017-06-24 14:44:521573Durchsuche

Dekorator bedeutet Dekorateur

1. Konzept

Ein Dekorator ist eine Funktion, die zum Ändern des Verhaltens einer Klasse verwendet wird (Hinweis: 1. Funktion 2. Verhalten ändern 3. Auf Klasse einwirken)

1. Schreibgeschützter Modifikator

{
  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());
}

 Sie können es auch vor der Klasse ändern

{
  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();
}

Das obige ist der detaillierte Inhalt vonDetaillierte Einführung in Decorator in ES6. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn