首页 > 其他 > 详细

ts中的装饰器

时间:2019-10-27 19:49:19      阅读:105      评论:0      收藏:0      [点我收藏+]
// 装饰器一种特殊的类的声明, 扩展类、属性、方法。
function logClass(params:any) {
  console.log(params); // params代表HttpClict这个类
  params.propotype.apiurl = ‘fadsf‘;
}
// 普通装饰器
@logClass
class HttpClict {
  constructor() {

  }
  getdata() {

  }
}
// 装饰器工厂
//类装饰器
function logClass1(params:any) {
  return function(target:any) {
    console.log(target) //当前类
    console.log(params) // 调用装饰器传入实参
  }
}
//属性装饰器
function attr(params:any) {
  return function(target:any,attr:any){
    console.log(params) // 属性url传入的形参
    console.log(target) // 当前类
    console.log(attr) //当前属性名称
    target[attr] = params; // 修改构造函数里面的属性
  }
}
// 方法装饰器
/**
* 方法装饰器会在运行时传入三个参数
* 1.对于静态成员来说是类的构造函数,对于实例成员是类的原型对象
* 2.成员的名字
* 3.成员属性的描述符
*/

function logMethod(params:any) {
  return function(target:any,methodName:any,desc:any) {
    console.log(target)
    console.log(methodName)
    console.log(desc)
  }
}
//方法参数装饰器
/**
* 1.对于静态成员来说是类的构造函数,对于实例成员来说是类的原型对象
* 2.参数 的名字
* 3.参数在函数参数列表中的索引
*/
function logParams(params:string) {
  return function(target:any,methodName:any,paramsIndes:any) {
    console.log(target)
    console.log(methodName)
    console.log(paramsIndes)
}
}
@logClass1(‘fsdf‘)
class HttpClict1 {
  @attr(‘12‘)
  url:string | undefined;
  constructor() {

  }
  @logMethod(‘123‘)
  getdata(@logParams(‘12‘) param:any) {

  }
}

// 装饰器执行顺序
// 属性装饰器 -> 方法装饰器 -> 类装饰器
// 相同装饰器从后向前执行。

ts中的装饰器

原文:https://www.cnblogs.com/windcat/p/11748381.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!