关于jQuery的$.proxy()应用.

今天在看<<锋利的jQuery>>时看到了proxy()的使用,感觉很模糊,就到处找资料.

jQuery的源码也没看明白.

不过总算明白了proxy的用法了;

1 <input  type="button" value="测试" id="guoBtn" name="我是按钮的name"/>
 1 var obj = {
 2                 name: "我是obj的name",
 3                 sayName: function () {
 4                     alert(this.name);
 5                 }
 6             }
 7 $("#guoBtn").click(obj.sayName); //我是按钮的name
 8 // 如果我想访问obj的name怎么办呢?  
 9 $("#guoBtn").click($.proxy(obj.sayName,obj));//"我是obj的name"
10 $("#guoBtn").click($.proxy(obj, "sayName")); //"我是obj的name"

从上面proxy(a,b)的用法可以看出他的参数有两种写法.

第一种:a是一个function函数,b是这个函数的对象所有者.

第二种:a是一个对象,b是一个字符串,是a的属性名.

还有这个实例就是<<锋利的jQuery>>上的一个例子了.

1 <div id="panel" style="display:none;">
2     <button>Close</button>
3 </div>
1 $("#panel").fadeIn(function () {
2        $("#panel button").click(function () {
3            $(this).fadeOut();
4           });
5         });

button虽然消失了,但是panel却没有消失.可以使用proxy来解决这个问题.

1 $("#panel").fadeIn(function () {
2                 var obj = this;
3                 $("#panel button").click($.proxy(function () {
4                     $(this).fadeOut();
5                 }, obj));
6             });

这样单击按钮之后,panel才会消失.

个人感觉proxy最主要就是用来修改函数执行时的上下文对象的.

是在apply的基础上做的封装,所以说proxy就是我们jQuery自己的apply.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值