console.log('装饰器.......')
// 装饰器就是一个方法,可以注入到类,方法,属性上来拓展类,属性,方法,参数的功能
// 常见:类装饰器,属性装饰器,方法装饰器,参数装饰器
// 写法:1.普通装饰器(无法传参) 2.装饰器工厂(可传参) // 1.类装饰器
// 类装饰器在类声明之前被声明(紧靠着类声明)。 类装饰器应用于类构造函数,可以用来监视,修改或替换类定义。
// 普通装饰器(无法传参)
function logClass(params: any) {
console.log(params)
// 通过原型链拓展类,属性,方法,参数
params.prototype.apiUrl = 'xxx'
params.prototype.run = function () {
console.log('run...........')
}
} @logClass
class HttpClient {
constructor() {}
getData() {}
}
let http: any = new HttpClient()
console.log(http)
http.run() // 装饰器工厂(可传参)
function logClass1(params: string) {
return function (target: any) {
console.log(params)
console.log(target)
target.prototype.apiUrl = params
}
} @logClass1('hello')
class HttpClient1 {
constructor() {}
getData() {}
}
let http1: any = new HttpClient1()
console.log(http1) // 重载构造函数
function logClass2(target: any) {
return class extends target {
api: any = 'api2222'
getData() {
console.log(this.api + '333')
}
}
} @logClass2
class HttpClient2 {
public api: string | undefined
constructor() {
this.api = 'api11111'
}
getData() {
console.log(this.api)
}
}
let http2: any = new HttpClient2()
console.log(http2)
http2.getData() // 2.属性装饰器
// 属性装饰器表达式会在运行时被当作函数调用
// 接收两个参数
// 1. 对于静态成员是类的构造函数,对于实例成员是类的原型对象
// 2. 成员的名字 // 类装饰器
function logClass3(params: string) {
return function (target: any) {
// console.log(params)
// console.log(target)
target.prototype.apiUrl = params
}
} // 属性装饰器
function logProperty(params: string) {
return function (target: any, attr: any) {
// console.log(params)
// console.log(target)
target[attr] = params
}
} @logClass3('hello33333')
class HttpClient3 {
@logProperty('hello4444')
public api: any | undefined
constructor() {}
getData() {}
}
let http3: any = new HttpClient3()
console.log(http3) // 3.方法装饰器
// 应用在方法的属性描述上,可以用来监视、修改、替换方法定义
// 接收三个参数
// 1. 对于静态成员是类的构造函数,对于实例成员是类的原型对象
// 2. 成员的名字
// 3. 成员的属性的描述
function logClass4(params: string) {
return function (target: any, methodsName: any, desc: any) {
console.log(target)
console.log(methodsName)
console.log(desc)
console.log(desc.value)
let o = desc.value
desc.value = function (...args: any[]) {
args = args.map((item) => {
return String(item) + params
})
o.apply(this, args)
}
}
} class HttpClient4 {
public api: any | undefined
constructor() {}
@logClass4('方法装饰器方法装饰器方法装饰器方法装饰器')
getData(...args: any[]) {
console.log(args)
console.log('getDatagetDatagetData')
}
}
let http4: any = new HttpClient4()
http4.getData(123, 'xxx') // 4.参数装饰器
// 参数装饰器表达式会在运行时当作函数被调用,可以使参数装饰器为类的原型增加一些元素数据
// 1. 对于静态成员是类的构造函数,对于实例成员是类的原型对象
// 2. 参数的名字
// 3. 参数索引
function logClass5(params: string) {
return function (target: any, methodsName: any, desc: any) {
console.log(target)
console.log(methodsName)
console.log(desc)
}
} class HttpClient5 {
public api: any | undefined
constructor() {} getData(@logClass5('参数装饰器参数装饰器') uuid: any) {
console.log(uuid)
}
}
let http5: any = new HttpClient5()
http5.getData(1232123) // 装饰器执行顺序
// 属性>方法参数>方法>>类
// 存在多个同样装饰器则是从下到上执行
function logClass6(params: string) {
return function (target: any, methodsName: any, desc: any) {
console.log(params)
}
}
function logClass7(params: string) {
return function (target: any, methodsName: any, desc: any) {
console.log(params)
}
}
function logClass8(params: string) {
return function (target: any, methodsName: any, desc: any) {
console.log(params)
}
}
function logClass9(params: string) {
return function (target: any, methodsName: any, desc: any) {
console.log(params)
}
} function logClass10(params: string) {
return function (target: any) {
console.log(params)
}
} function logClass11(params: string) {
return function (target: any, attr: any) {
console.log(params)
}
} @logClass10('类装饰器装饰器')
class HttpClient6 {
@logClass11('属性装饰器')
public api: any | undefined
constructor() {}
@logClass8('方法装饰器装饰器1')
@logClass9('方法装饰器装饰器2')
getData(
@logClass6('参数装饰器1') uuid1: any,
@logClass7('参数装饰器2') uuid2: any
) {
console.log(uuid1)
console.log(uuid2)
}
}
let http6: any = new HttpClient6()
http6.getData(1232123, 234)

ts的装饰器的更多相关文章

  1. ts装饰器的用法,基于express创建Controller等装饰器

    TS TypeScript 是一种由微软开发的自由和开源的编程语言.它是 JavaScript 的一个超集,而且本质上向这个语言添加了可选的静态类 型和基于类的面向对象编程. TypeScript 扩 ...

  2. TS 自学笔记(二)装饰器

    TS 自学笔记(二)装饰器 本文写于 2020 年 9 月 15 日 上一篇 TS 文章已经是很久之前了.这次来讲一下 TS 的装饰器. 对于前端而言,装饰器是一个陌生的概念,但是对于 Java.C# ...

  3. ts中的装饰器

    // 装饰器一种特殊的类的声明, 扩展类.属性.方法. function logClass(params:any) { console.log(params); // params代表HttpClic ...

  4. JS中bind、call和apply的作用以及在TS装饰器中的用法

    目录 1,前言 1,call 1.1,例子 1.2,直接调用 1.3,将this指向另一个对象 1.4,传递参数 2,apply 2.1,例子 2.2,直接调用 2.3,将this指向另一个对象 2. ...

  5. python-大话装饰器

    装饰器 装饰器是个什么玩意呢?是个会了不难,装逼神器.但是如果不了解理解起来还是很抽象,让我们试试这个装逼神器吧! 1.什么是装饰器 装饰器是一个很著名的设计模式,经常被用于有切面需求的场景,较为经典 ...

  6. Python学习笔记——基础篇2【第三周】——计数器、有序字典、元组、单(双)向队列、深浅拷贝、函数、装饰器

    目录 1.Python计数器Counter 2.Python有序字典OrderredDict 3.Python默认字典default 4.python可命名元组namedtuple 5.Python双 ...

  7. 基于TypeScript装饰器定义Express RESTful 服务

    前言 本文主要讲解如何使用TypeScript装饰器定义Express路由.文中出现的代码经过简化不能直接运行,完整代码的请戳:https://github.com/WinfredWang/expre ...

  8. TypeScript装饰器(decorators)

    装饰器是一种特殊类型的声明,它能够被附加到类声明,方法, 访问符,属性或参数上,可以修改类的行为. 装饰器使用 @expression这种形式,expression求值后必须为一个函数,它会在运行时被 ...

  9. JS 装饰器解析

    随着 ES6 和 TypeScript 中类的引入,在某些场景需要在不改变原有类和类属性的基础上扩展些功能,这也是装饰器出现的原因. 装饰器简介 作为一种可以动态增删功能模块的模式(比如 redux ...

  10. 【Angular专题】 (3)装饰器decorator,一块语法糖

    目录 一. Decorator装饰器 二. Typescript中的装饰器 2.1 类装饰器 2.2 方法装饰器 2.3 访问器装饰器 2.4 属性装饰器 2.5 参数装饰器 三. 用ES5代码模拟装 ...

随机推荐

  1. 06#Web 实战:可滑动的标签页

    实现效果图 本随笔只是记录一下大概的实现思路,如果感兴趣的小伙伴可以通过代码和本随笔的说明去理解实现过程.我的 Gitee 和 GitHub 地址.注意哦:这个只是 PC 上的标签页,手机端的没用,因 ...

  2. Canvas:绘制矩形

    函数 CanvasPath.rect(x, y, w, h) 参数名 类型 描述 x Number 矩形起始位置 y Number 矩形起始位置 w Number 矩形宽度 h Number 矩形高度 ...

  3. pip换源和制作虚拟环境操作步骤讲解

    目录 一.pip换源及虚拟环境 二.虚拟环境 一.pip换源及虚拟环境 我们Python的强大之处就是有非常多的牛逼的第三方模块,后面的程序员只需要下载第三方模块,然后站在大佬们的肩膀上开发,第三方开 ...

  4. sqlserver update join

    update a set a.UserAgent = b.UserAgent from InfoVisitDetails a inner join InfoVisitDetails b on a.IP ...

  5. linux配置爬虫环境

    #宝塔面板安装python3 #安装依赖包 yum -y groupinstall "Development tools" yum -y install zlib-devel bz ...

  6. Mybatis plus 查询

    1.子查询 // 管理主管查询 Integer manageSupervisor = query.getManageSupervisor(); if (manageSupervisor != null ...

  7. ubuntu20.04虚拟机无法自动获取IP地址

    具体操作 # ens33 为网卡名称 sudo dhclient ens33

  8. 在IIS上同站点部署多个程序操作步骤

    1.打开IIS管理器: 2.右击选中"网站",选择"添加网站":输入网站名称.路径.IP地址等信息: 3.确定后并访问网站: 部署后可能会因为框架不支持导致报错 ...

  9. vue页面添加锚点后 点击不改变URL

    html: <a @click="changeHash('#row')"> {{ $t("msg.desc1") }} </a>   j ...

  10. 使用open打开子页面时,父页面关闭子页面操作

    <button onclick="open1()">kaiqi</button> <button onclick="close1()&quo ...