JavaScript-装饰器函数(Decorator)

JavaScript-装饰器函数(Decorator)

用于给对象在运行期间动态的增加某个功能,职责等。相较通过继承的方式来扩充对象的功能,装饰器显得更加灵活,首先,我们可以动态给对象选定某个装饰器,而不用hardcore继承对象来实现某个功能点。其次:继承的方式可能会导致子类繁多,仅仅为了增加某一个单一的功能点,显得有些多余了。

下面给出几个常用的装饰器函数示例,相关代码请查看github

1 动态添加onload监听函数
        function addLoadEvent(fn) {
   
            var oldEvent = window.onload;
            if(typeof window.onload != 'function') {
                window.onload = fn;
            }else {
                window.onload = function() {
   
                    oldEvent();
                    fn();
                };
            }
        }
        function fn1() {
   
            console.log('onloadFunc 1');
        }
        
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
是的,JavaScript引入了装饰器的概念,可以使用装饰器来修改类和类的成员。装饰器是一个函数,它可以接收一个类或类的成员作为参数,并且可以返回一个新的类或修改后的成员。 以下是一个使用装饰器修改类的示例: ``` function classDecorator(target) { // 在类名前后添加一些字符串 target.className = `decorated_${target.name}_class`; return target; } @classDecorator class MyClass { // ... } console.log(MyClass.className); // 输出为 "decorated_MyClass_class" ``` 在上面的例子中,`classDecorator`是一个装饰器函数,它接收一个类作为参数,并且在类名前后添加一些字符串。在类定义前面加上 `@classDecorator`,就可以使用装饰器来修改类。 以下是一个使用装饰器修改类成员的示例: ``` function methodDecorator(target, key, descriptor) { // 保存原始方法 const originalMethod = descriptor.value; // 修改方法 descriptor.value = function(...args) { console.log(`Method ${key} called with arguments: ${args.join(', ')}`); return originalMethod.apply(this, args); }; return descriptor; } class MyClass { @methodDecorator myMethod(x, y) { return x + y; } } const obj = new MyClass(); obj.myMethod(1, 2); // 输出 "Method myMethod called with arguments: 1, 2" console.log(obj.myMethod(1, 2)); // 输出 3 ``` 在上面的例子中,`methodDecorator`是一个装饰器函数,它接收三个参数:类的原型对象(即类的成员所在的对象)、成员名和成员的描述符。在这个例子中,`methodDecorator`修改了类的一个方法,添加了一些额外的日志输出。在方法定义前面加上 `@methodDecorator`,就可以使用装饰器来修改方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值