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

 更新时间:2016年05月24日 16:43:09   作者:Aaron  
proxy()主要用于在同样的上下文语境中指向另一个对象,下面我们就以实例解析jQuery中proxy()函数的用法,需要的朋友可以参考下

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);

});

相关文章

  • jQuery实现动态粒子效果

    jQuery实现动态粒子效果

    这篇文章主要为大家详细介绍了jQuery实现动态粒子效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-03-03
  • jquery 学习之二 属性(html()与html(val))

    jquery 学习之二 属性(html()与html(val))

    取得第一个匹配元素的html内容。这个函数不能用于XML文档。但可以用于XHTML文档。
    2010-11-11
  • jQuery插件制作的实例教程

    jQuery插件制作的实例教程

    一款优秀的jQuery插件,要做到通用、灵活度高、可配置、兼容性好、易用性高、耦合度低...想要做到这些,嘿嘿,那么就来看今天所介绍的jQuery插件制作的实例教程.
    2016-05-05
  • jQuery+CSS实现简单切换菜单示例

    jQuery+CSS实现简单切换菜单示例

    这篇文章主要介绍了jQuery+CSS实现简单切换菜单的方法,涉及jQuery针对页面元素的遍历及样式动态变换相关技巧,需要的朋友可以参考下
    2016-07-07
  • jQuery同步提交示例代码

    jQuery同步提交示例代码

    这篇文章主要介绍了jQuery同步提交实现方法,实例分析了jQuery基于ajax实现同步提交的具体技巧,以及jQuery版本更新的使用注意事项,需要的朋友可以参考下
    2015-12-12
  • jQuery布局组件EasyUI Layout使用方法详解

    jQuery布局组件EasyUI Layout使用方法详解

    这篇文章主要为大家详细介绍了jQuery布局组件EasyUI Layout的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • jQuery 和 CSS 的文本特效插件集锦

    jQuery 和 CSS 的文本特效插件集锦

    这篇文章主要汇总了20种jQuery 和 CSS 的文本特效插件,都是比较热门的特效插件,推荐给有需要的小伙伴。
    2014-12-12
  • Jquery跨域获得Json时invalid label错误的解决办法

    Jquery跨域获得Json时invalid label错误的解决办法

    这两天用 Jquery 跨域取数据的时候,经常碰到 invalid label 这个错误,十分的郁闷,老是取不到服务器端发送回来的 json 值,一般跨域用到的两个方法为:$.ajax 和 $.getJson
    2011-01-01
  • Jquery实现仿新浪微博获取文本框能输入的字数代码

    Jquery实现仿新浪微博获取文本框能输入的字数代码

    Jquery实现仿新浪微博获取文本框所能输入的字数,感兴趣的朋友可以研究一下代码方便你折腾,希望本文提供的方法可以帮助到你
    2013-02-02
  • jQuery使用each方法与for语句遍历数组示例

    jQuery使用each方法与for语句遍历数组示例

    这篇文章主要介绍了jQuery使用each方法与for语句遍历数组,结合实例形式简单对比分析了两种方法在遍历数组时的实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-06-06

最新评论