博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
es7 class装饰器
阅读量:6270 次
发布时间:2019-06-22

本文共 1262 字,大约阅读时间需要 4 分钟。

文档

ts文档

当多个装饰器应用于一个声明上,从上至下调用,从下而上执行

interface InfoOpt {  username: string;  age: number;  email: string;}function Info(opt: InfoOpt) {  return function (target) {    target.username = opt.username;    target.age = opt.age;    target.email = opt.email;  }}@Info({  username: 'ajanuw',  age: 14,  email: '123@sina.com'})class AJanuw {  constructor() { }}console.log(  AJanuw.username,  AJanuw.age,  AJanuw.email,);

es 的装饰器

let l = console.logfunction klass(value) {    return target => {        // l(value) // api        // l(target) // 对象    }}function prop(value) {    return function (target, key, des) { // target 对于静态成员来说是类的构造函数,对于实例成员是类的原型对象        // l(value) // username        // l(target, key, des) // 对象,属性名,属性描述符    }}function func(value) {    return function (target, key, des) { // // target 对于静态成员来说是类的构造函数,对于实例成员是类的原型对象        // l(value) // function        // l(key) // 函数名 show        // l(des.value) // show函数, 可以改写        // des.value = function(){        //     l('hello')        // }    }}function Body(target) {    // l( target ) // undefined}@klass('api')class Ajanuw {    @prop('username') name = 'ajanuw'    @func('function')    show(@Body body) {        l(body)    }}new Ajanuw().show()

转载于:https://www.cnblogs.com/ajanuw/p/8934150.html

你可能感兴趣的文章
ES6里关于类的拓展(一)
查看>>
零元学Expression Blend 4 - Chapter 46 三分钟快速充电-设定Margin的小撇步
查看>>
Format Conditions按条件显示表格记录
查看>>
RichTextBox指定全部文字显示不同颜色及部分文字高亮颜色显示
查看>>
mysql优化----explain的列分析
查看>>
Python正则表达式
查看>>
Java中CAS详解
查看>>
Spring Boot Unregistering JMX-exposed beans on shutdown
查看>>
命令行man的帮助手册
查看>>
Ubuntu 16.04下为Android编译OpenCV 3.2.0 Manager
查看>>
poi 导入导出的api说明(大全)
查看>>
Fix-Mapped Addresses
查看>>
fmt标签如何计算两个日期之间相隔的天数
查看>>
Spark核心技术原理透视一(Spark运行原理)
查看>>
《Gradle权威指南》--Gradle任务
查看>>
IntelliJ IDEA创建文件时自动填入作者时间 定制格式
查看>>
Android app启动activity并调用onCreate()方法时都默默地干了什么?
查看>>
远程监视jboss应用java内存的配置
查看>>
前端如何接收 websocket 发送过来的实时数据
查看>>
JavaWeb下载文件response
查看>>