网站首页  汉语字词  英语词汇  考试资料  写作素材  旧版资料

请输入您要查询的范文:

 

标题 实例解析jQuery中proxy()函数的用法
范文
    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);
    });
随便看

 

在线学习网范文大全提供好词好句、学习总结、工作总结、演讲稿等写作素材及范文模板,是学习及工作的有利工具。

 

Copyright © 2002-2024 cuapp.net All Rights Reserved
更新时间:2025/5/21 0:12:55