开发学院网页设计JavaScript js动态代理 阅读

js动态代理

 2010-09-14 13:46:37 来源:WEB开发网 闂傚倸鍊风欢姘缚瑜嶈灋闁圭虎鍠栫粻顖炴煥閻曞倹瀚�闂傚倸鍊风粈渚€骞夐敓鐘插瀭闁汇垹鐏氬畷鏌ユ煙閹殿喖顣奸柛搴$У閵囧嫰骞掗幋婵冨亾閻㈢ǹ纾婚柟鐐灱濡插牊绻涢崱妤冃℃繛宀婁簽缁辨捇宕掑鎵佹瀸闂佺懓鍤栭幏锟�濠电姷鏁告慨顓㈠箯閸愵喖宸濇い鎾寸箘閹规洟姊绘笟鈧ḿ褍煤閵堝悿娲Ω閳轰胶鍔﹀銈嗗笂閼冲爼鍩婇弴銏$厪闁搞儮鏅涙禒褏绱掓潏鈺佷槐闁轰焦鎹囬弫鎾绘晸閿燂拷闂傚倸鍊风欢姘缚瑜嶈灋闁圭虎鍠栫粻顖炴煥閻曞倹瀚�  闂傚倸鍊烽懗鑸电仚缂備胶绮〃鍛村煝瀹ュ鍗抽柕蹇曞У閻庮剟姊虹紒妯哄妞ゆ劗鍘ч埥澶娢熼柨瀣偓濠氭⒑瑜版帒浜伴柛鎾寸☉閳绘柨顫濋懜纰樻嫼闂佸憡绋戦オ鏉戔枔閺冣偓缁绘稓浠﹂崒姘瀳闂佸磭绮幑鍥嵁鐎n亖鏀介柟閭﹀墯椤斿倹淇婇悙顏勨偓鏍ь潖婵犳艾鍌ㄧ憸蹇涘箟閹绢喗鏅搁柨鐕傛嫹
核心提示: 要拦截函数很简单,以被拦截的函数名和用于拦截的函数为参数$.intercept=function('objectName.methodName',function(){//dosomething//andinvoketheoriginalmethodifneeded thi

要拦截函数很简单,以被拦截的函数名和用于拦截的函数为参数

$.intercept = function('objectName.methodName', function(){
//do something
//and invoke the original method if needed
    this.__invocation();
})

当然现实中我的js动态代理代码里的函数几乎都是私有或匿名的(这是避免命名冲突的最佳实践),并且我通常只想修改其中的一两行代码。于是我再写多了个方法,实现实时包装和调用。

原本是这样

$('#clickMe2').click(function(){
     alert('这是匿名函数,休想跨作用域追捕');
     alert($('#content').text());
});

改成这样,就可以照样用 intercept() 插一脚了,虽然原来的代码也需要修改,但是至少它不包含自定义的逻辑

$('#clickMe2').click(function(){
    $._('fuck_them_up', function(){
        alert('这是匿名函数,休想跨作用域追捕');
        alert($('#content').text());
    });
});

Demo,看看点intercept me之前和之后点 click me 会有什么不同?

function fuckThemUp(s){
    alert(s);
}
$('#clickMe').click(function(){
    fuckThemUp($('#content').text());
});
$('#interceptMe').click(function(){
    $.intercept('fuckThemUp', function(s){
        alert('河蟹来了!');
        s = s.replace(/修脚刀/, '水果刀');
        s = s.replace(/特殊服务/, '异性洗浴服务');
        s = s.replace(/按倒/, '推坐');
        this.__invocation__(s);
    });
});
$('#clickMe2').click(function(){
    $._('fuck_them_up', function(){
        alert('这是匿名函数,休想跨作用域追捕');
    });
});
$('#interceptMe2').click(function(){
    $.intercept('fuck_them_up', function(s){
        alert('还不抓到你?');
    });
});

 

上一页  1 2 

Tags:js 动态 代理

编辑录入:爽爽 [复制链接] [打 印]
[]
  • 好
  • 好的评价 如果觉得好,就请您
      0%(0)
  • 差
  • 差的评价 如果觉得差,就请您
      0%(0)
赞助商链接