时间:2021-05-18
jQuery.proxy(),接受一个函数,然后返回一个新函数,并且这个新函数始终保持了特定的上下文(context )语境。
jQuery.proxy( function, context )function将要改变上下文语境的函数。
context函数的上下文语境(`this`)会被设置成这个 object 对象。
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()只传入函数的参数,而不更改函数的上下文。
实例
我们先看个例子:
//正常的this使用$('#Haorooms').click(function() { // 这个this是我们所期望的,当前元素的this. $(this).addClass('aNewClass');});//并非所期望的this$('#Haorooms').click(function() { setTimeout(function() { // 这个this指向的是settimeout函数内部,而非之前的html元素 $(this).addClass('aNewClass'); }, 1000);});这时候怎么办呢,通常的一种做法是这样的:
$('#Haorooms').click(function() { var that = this; //设置一个变量,指向这个需要的this setTimeout(function() { // 这个this指向的是settimeout函数内部,而非之前的html元素 $(that).addClass('aNewClass'); }, 1000);});但是,在使用了jquery框架的情况下, 有一种更好的方式,就是使用$.proxy函数。
有两种语法:
jQuery.proxy( function, context )/**function将要改变上下文语境的函数。** context函数的上下文语境(`this`)会被设置成这个 object 对象。**/jQuery.proxy( context, name )/**context函数的上下文语境会被设置成这个 object 对象。**name将要改变上下文语境的函数名(这个函数必须是前一个参数 ‘context' **对象的属性)**/上面的例子使用这种方式就可以修改成:
$('#Haorooms').click(function() { setTimeout($.proxy(function() { $(this).addClass('aNewClass'); }, this), 1000);});声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了jQuery中attr()与prop()函数用法。分享给大家供大家参考,具体如下:一、jQuery的attr()方法jquery中用attr()方
本文实例讲述了jquery中map函数遍历数组用法。分享给大家供大家参考。具体如下:map函数$(func
本文实例讲述了jQuery回调函数的定义及用法。分享给大家供大家参考。具体分析如下:jQuery代码中对回调函数有着广泛的应用,对其有精准的理解是非常有必要的,
本文实例讲述了JavaScript的级联函数用法。分享给大家供大家参考,具体如下:级联函数级联函数就是在对象调用中通过点的方式串联调用,在jQuery中就是链式
本文实例讲述了jQuery中ajax的load()方法用法。分享给大家供大家参考。具体分析如下:此函数jQuery中简单而功能强大的ajax方法。它可以从服务器