实例解析jQuery中proxy()函数的用法

jQuery.proxy(),接受一个函数,然后返回一个函数,并且这个新函数始终保持了特定的上下文(context )语境。

rush:js;"> jQuery.proxy( function,context )

function将要改变上下文语境的函数

context函数的上下文语境(`this`)会被设置成这个 object 对象。

rush:js;"> jQuery.proxy( context,name )

context函数的上下文语境会被设置成这个 object 对象。

name将要改变上下文语境的函数名(这个函数必须是前一个参数 ‘context' 对象的属性)

这个方法通常在向一个元素上附加事件处理函数时,上下文语境实际是指向另一个对象的情况下使用。

另外,jQuery 能够确保即使你绑定的函数是经过 jQuery.proxy() 处理过的函数,你依然可以用原先的函数来正确地取消绑定。

参数:

function:Function类型需要更改上下文对象的函数。 context:任意类型指定为函数设置的上下文对象。 name:String类型需要更改上下文对象的函数名称(它应该是context的一个属性)。 additionalArguments可选/任意类型指定调用函数时需要传入的参数,参数可以有任意多个。

注意事项:

参数additionalArguments是从 jQuery 1.6 开始支持的。 该方法非常适用于在附加事件处理函数时,将事件处理函数的上下文指向另一个对象。此外,jQuery确保:即使你使用jQuery.proxy()返回的"代理"函数来绑定事件,如果你在解除绑定时传入原函数,jQuery仍然可以正确解除绑定。 从jQuery 1.9 开始,如果context为null或undefined,则"代理"函数的上下文不会发生更改。这将允许jQuery.proxy()只传入函数的参数,而不更改函数的上下文。

实例

我们先看个例子:

rush:js;"> //正常的this使用 $('#Haorooms').click(function() {

// 这个this是我们所期望的,当前元素的this.

$(this).addClass('aNewClass');

});
//并非所期望的this
$('#Haorooms').click(function() {

setTimeout(function() {

 // 这个this指向的是settimeout<a href="https://www.jb51.cc/tag/hanshu/" target="_blank" class="keywords">函数</a>内部,而非之前的html元素

$(this).addClass('aNewClass');

},1000);

});

这时候怎么办呢,通常的一种做法是这样的:

rush:js;"> $('#Haorooms').click(function() { var that = this; //设置一个变量,指向这个需要的this

setTimeout(function() {

 // 这个this指向的是settimeout<a href="https://www.jb51.cc/tag/hanshu/" target="_blank" class="keywords">函数</a>内部,而非之前的html元素

$(that).addClass('aNewClass');

},1000);

});

但是,在使用了jquery框架的情况下, 有一种更好的方式,就是使用$.proxy函数

有两种语法:

rush:js;"> jQuery.proxy( function,context ) /**function将要改变上下文语境的函数。 ** context函数的上下文语境(`this`)会被设置成这个 object 对象。 **/

jQuery.proxy( context,name )
/context函数的上下文语境会被设置成这个 object 对象。
name将要改变上下文语境的函数名(这个函数必须是前一个参数 ‘context' 对象的属性)
/

上面的例子使用这种方式就可以修改成:

rush:js;"> $('#Haorooms').click(function() {

setTimeout($.proxy(function() {

$(this).addClass('aNewClass'); 

},this),1000);

});

相关文章

页面搜索关键词突出 // 页面搜索关键词突出 $(function () {...
jQuery实时显示日期、时间 html: &lt;span id=&quot...
jQuery 添加水印 &lt;script src=&quot;../../../.....
中文:Sys.WebForms.PageRequestManagerParserErrorExceptio...
1. 用Response.Write方法 代码如下: Response.Write(&q...
Jquery实现按钮点击遮罩加载,处理完后恢复 思路: 1.点击按...