装饰者模式试玩

装饰者模式实践
本文探讨了装饰者模式在JavaScript中的应用,并通过实例演示了如何利用该模式为对象添加新功能而不改变其原有结构。同时讨论了函数式写法中的一些挑战及解决方法。

今天突然想玩玩装饰者模式。

这个模式行为是,给对象加一个新方法,在不改变对象原因有方法的基础上。

网上找到的示例代码如下:

function ABicycle(){ }
ABicycle.prototype = {
    wash : function(){ },
    ride : function(){ },
    getPrice : function(){ 
        return 999; 
    }
}

function bicycleBell( bicycle ){
    var price= bicycle.getPrice();

    bicycle.bell = function(){
        console.log("ding! ding! ding!");
    };

    bicycle.getPrice = function(){
            return price + 100;
    };
    return bicycle;
}

var bicycleA = new ABicycle();
bicycleA = bicycleBell( bicycleA );

 

我异想天开,想用函数的方法,且改变函数的原有结构。

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>装饰者模式——函数式写法</title>
        <script type="text/javascript">
            function a1(){
                return 3;
            }
            
            function addA(aFn){
                var c= aFn();
                aFn = function(){
                    return c + 2;
                }

            }
            
//            function addA(aFn){
//                var c= aFn();
//
//                var aFnName = aFn.name;
//                eval(aFnName +' = function(){return c + 2;}');
//
//            }
//            
            console.log(a1());
            addA(a1);
            console.log(a1());
        </script>
    </head>
    <body>
        
    </body>
</html>

代码执行,当然不行啦,因为函数和数字,字符串一样都是值传递。倒是数组,对象是引用传递。

用邪恶的eval,把注释去掉,就可以啦。

这样的做法,挺坏。会使得程序不好预测。

 

转载于:https://www.cnblogs.com/samwu/p/4063418.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值