深入理解js--面向切面编程 AOP
深入理解js--面向切面编程 AOP
招展君 发表于2年前
深入理解js--面向切面编程 AOP
  • 发表于 2年前
  • 阅读 20
  • 收藏 0
  • 点赞 0
  • 评论 0

腾讯云 新注册用户 域名抢购1元起>>>   

js高级--面向切面编程

function demo(){
    alert('2');
    return 'me test';
}

Function.prototype.before= function (fn) {
    var __self = this;
    return function () {
        //这里面的this指向已经发生了变化,谁调用 就指向谁
        if(fn.apply(this,arguments)==false){
            return false;
        }
       return __self.apply(__self,arguments);
    }
}
Function.prototype.after = function (fn) {
    var __self = this;
    return function () {
        var result = __self.apply(__self,arguments);
        if(result ==false){
            return false;
        }
        fn.apply(this,arguments);
        return result;
    }
}

//默认函数被执行两遍,现在思路是要以默认函数为中转
//让默认函数先不执行,
// before回调和before一起送到after里去
//after回调和after也要送到before里去

//将AOP函数改成可以链式触发的函数
var s = demo.before(function () {
    alert('1');
}).after(function () {
    alert('3');
})()

console.log(s);

共有 人打赏支持
粉丝 0
博文 8
码字总数 2941
×
招展君
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: