Decorators修饰器

修饰器是一个函数,通过修饰器能修改类的行为,也可理解为扩展类的功能,在类这个范围内有效。

插件

使用修饰器还需要安装一个插件 import babel-plugin-transform-decorators-legacy在.babelrc文件中引入如下文件:

  1. ```javascript
  2. {
  3. "plugins":["transform-decorators-legacy"]
  4. }

注意: ES6中默认开启严格模式,要在ES5中使用需要有这句命令 use strict 强制开启严格模式。

案例

  • 案例一:限制某个属性为只读

修饰器的第三方js库:core-decorators; npm install core-decorators,import引入后,直接在项目中写@readonly就可以了,不用向下面在定义readonly```javascript{ let readonly = function(target,name,descriptor){ descriptor.writable = false; return descriptor; }

class Test{ @readonly time(){ return ‘2017-06-14’; } }

let t1 = new Test(); console.log(t1.time()); //2017-06-14

let t2 = new Test();

//此时 time为只读 再次设置将会报下面错误 t2.time = function(){ console.log(‘reset time’); }

console.log(t2.time()); //Uncaught TypeError: Cannot assign to read only property ‘time’ of object ‘#‘}

  1. - **案例一:点击统计**
  2. > 日志系统,比如广告,我们会为其做展示、点击统计
  3. ```javascript
  4. {
  5. //先写一个修饰器,type表示的是show 还是 click
  6. let log = (type) => {
  7. return function(target,name,descriptor){
  8. //保存一下原始的函数体
  9. let src_method = descriptor.value;
  10. //重新进行赋值
  11. descriptor.value = (...arg) => {
  12. src_method.apply(target,arg);
  13. //如果将来发送买点接口变了,只需要改log对应的这个方法就可以了
  14. console.info(`log ${type} `);
  15. }
  16. }
  17. }
  18. class AD{
  19. @log('show')
  20. show(){
  21. console.info('ad is show');
  22. }
  23. @log('click')
  24. click(){
  25. console.info('ad is click');
  26. }
  27. }
  28. let ad = new AD();
  29. ad.show();
  30. ad.click();
  31. }