装饰器

作者: 三省吾身_9862 | 来源:发表于2021-07-21 11:35 被阅读0次

装饰器有点像高阶函数;一个函数返回另一个函数;

装饰器是一个函数;用在类、类的属性、类的方法、类方法的参数上;功能就是把这些(类、类的属性、类的方法、类方法的参数);附加(装饰)上一定的额外的功能;

装饰器有两种:普通装饰器、装饰器工厂(可以传参数);这两种装饰器都可以用在(类、类的属性、类的方法、类方法的参数)上;

目前浏览器无法直接运行装饰器,一般用在typescript上,或者使用babel,才能运行。

类 装饰器

  • 类的普通装饰器
function lgClass(target:any) {
  // target是被装饰的类
  target.prototype.works = ['html', 'css']
}
// @lgClass不可以加;
@lgClass
class UlgClass {
  name: string;
  constructor(name: string) {
    this.name = name;
  }
}
  • 类的 装饰器工厂(可以传参数)
function clgClass (params: any[]) {
  return function (target:any) {
    // target是被装饰的类
    target.prototype.works = params;
  }
}
@clgClass(['html', 'css'])
class UlgClass {
  name: string;
  constructor(name: string) {
    this.name = name;
  }
}

普通装饰器,以下就不演示了,只演示 装饰器工厂(可以传参数)

类属性 装饰器

function logProperty(params: any) {
  // target 是被装饰类的原型; 用在静态方式属性,是类本身
  return function (target:any, key: any) {
    console.log(target)
    target[key] = params
  }
}

class UlgClass {
  @logProperty('http://baidu.com')
  url: string;
  constructor(url: string) {
    this.url = url;
  }
}

类方法 装饰器

function logMethod(params: any) {
  // target 是被装饰类的原型; 用在静态方式属性,是类本身
  return function (target:any, key: any, desc: any) {
    console.log(target, desc)
    var oMethod = desc.value;
    desc.value = function (...args:any[]) {
      args = args.map(val => String(val));
      oMethod.apply(this, args);
    }
  }
}

class Kk{
  name: string | undefined;
  @logMethod(null)
  eat() {}
}

类方法参数 装饰器

function logParams(params: string) {
  return function (target:any, methodName: string, paramsIndex: number) {
    console.log(target, methodName, paramsIndex)
  }
}

class Kk{
  eat(@logParams('fesh') food: string) {}
}

装饰器执行顺序

属性装饰器 - 方法装饰器 - 方法参数装饰器 - 类装饰器 (一个类或者方法、参数、属性:有多个装饰器,执行顺序:先下后上)

相关文章

  • 装饰器

    """@装饰器- 普通装饰器- 带参数的装饰器- 通用装饰器- 装饰器装饰类- 内置装饰器- 缓存装饰器- 类实现...

  • typescript 五种装饰器

    装饰器类型 装饰器的类型有:类装饰器、访问器装饰器、属性装饰器、方法装饰器、参数装饰器,但是没有函数装饰器(fun...

  • python——装饰器详解

    一、装饰器概念 1、装饰器 装饰器:一种返回值也是一个函数的函数,即装饰器。 2、装饰器目的 装饰器的目的:装饰器...

  • Python装饰器

    Python装饰器 一、函数装饰器 1.无参装饰器 示例:日志记录装饰器 2.带参装饰器 示例: 二、类装饰器 示例:

  • Python中的装饰器

    Python中的装饰器 不带参数的装饰器 带参数的装饰器 类装饰器 functools.wraps 使用装饰器极大...

  • 装饰器

    装饰器 decorator类装饰器 带参数的装饰器 举例(装饰器函数;装饰器类;有参与无参) https://fo...

  • TypeScript装饰器

    前言 装饰器分类 类装饰器 属性装饰器 方法装饰器 参数装饰器需要在tsconfig.json中启用experim...

  • python之装饰器模版

    装饰器的作用:装饰器即可以装饰函数也可以装饰类。装饰器的原理:函数也是对象 1.定义装饰器 2.使用装饰器假设de...

  • 装饰器实验

    装饰器实验 说明 ts内包含了四个装饰器,类装饰器、属性装饰器、函数装饰器、参数装饰器,本文中测试一下其的使用。 ...

  • python3基础---详解装饰器

    1、装饰器原理 2、装饰器语法 3、装饰器执行的时间 装饰器在Python解释器执行的时候,就会进行自动装饰,并不...

网友评论

      本文标题:装饰器

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