欢迎来到代码驿站!

jquery

当前位置:首页 > 网页前端 > jquery

jQuery的$.proxy()应用示例介绍

时间:2021-06-21 08:41:48|栏目:jquery|点击:
今天在看<<锋利的jQuery>>时看到了proxy()的使用,感觉很模糊,就到处找资料.

 

jQuery的源码也没看明白.

不过总算明白了proxy的用法了;
复制代码 代码如下:

<input type="button" value="测试" id="guoBtn" name="我是按钮的name"/>

复制代码 代码如下:

var obj = {
name: "我是obj的name",
sayName: function () {
alert(this.name);
}
}
$("#guoBtn").click(obj.sayName); //我是按钮的name
// 如果我想访问obj的name怎么办呢?
$("#guoBtn").click($.proxy(obj.sayName,obj));//"我是obj的name"
$("#guoBtn").click($.proxy(obj, "sayName")); //"我是obj的name"

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

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

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

还有这个实例就是<<锋利的jQuery>>上的一个例子了.
复制代码 代码如下:

<div id="panel" style="display:none;">
<button>Close</button>
</div>

复制代码 代码如下:

$("#panel").fadeIn(function () {
$("#panel button").click(function () {
$(this).fadeOut();
});
});


button虽然消失了,但是panel却没有消失.可以使用proxy来解决这个问题.
复制代码 代码如下:

$("#panel").fadeIn(function () {
var obj = this;
$("#panel button").click($.proxy(function () {
$(this).fadeOut();
}, obj));
});

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

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

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

上一篇:jQuery .attr()和.removeAttr()方法操作元素属性示例

栏    目:jquery

下一篇:jQuery检查事件是否触发的方法

本文标题:jQuery的$.proxy()应用示例介绍

本文地址:http://www.codeinn.net/misctech/145467.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有