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


Posted in Javascript onMay 24, 2016

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

});
Javascript 相关文章推荐
基于jQuery+HttpHandler实现图片裁剪效果代码(适用于论坛, SNS)
Sep 02 Javascript
对jQuery的事件绑定的一些思考(补充)
Apr 20 Javascript
javascript实现点击提交按钮后显示loading的方法
Jul 03 Javascript
jQuery+ajax简单实现文件上传的方法
Jun 03 Javascript
angular实现IM聊天图片发送实例
May 08 Javascript
Validform验证时可以为空否则按照指定格式验证
Oct 20 Javascript
基于vue-element组件实现音乐播放器功能
May 06 Javascript
小程序实现选择题选择效果
Nov 04 Javascript
详解Vue源码中一些util函数
Apr 24 Javascript
微信小程序:数据存储、传值、取值详解
May 07 Javascript
解决Vue 给mapState中定义的属性赋值报错的问题
Jun 22 Javascript
JavaScript中的执行环境和作用域链
Sep 04 Javascript
jQuery前端开发35个小技巧
May 24 #Javascript
JS+Canvas绘制时钟效果
Aug 20 #Javascript
基于JQuery实现图片上传预览与删除操作
May 24 #Javascript
JavaScript仿淘宝页面图片滚动加载及刷新回顶部的方法解析
May 24 #Javascript
通过jquery-ui中的sortable来实现拖拽排序的简单实例
May 24 #Javascript
ECHO.js 纯javascript轻量级延迟加载的实例代码
May 24 #Javascript
倾力总结40条常见的移动端Web页面问题解决方案
May 24 #Javascript
You might like
PHP 创建文件(文件夹)以及目录操作代码
2010/03/04 PHP
介绍一些PHP判断变量的函数
2012/04/24 PHP
PHP爆绝对路径方法收集整理
2012/09/17 PHP
javascript数组与php数组的地址传递及值传递用法实例
2015/01/22 PHP
PHP mysqli事务操作常用方法分析
2017/07/22 PHP
Laravel学习教程之从入口到输出过程详解
2017/08/27 PHP
PHP Web表单生成器案例分析
2020/06/02 PHP
详解PHP中curl_multi并发的实现
2020/06/08 PHP
js拦截alert对话框另类应用
2013/01/16 Javascript
window.open()详解及浏览器兼容性问题示例探讨
2014/05/29 Javascript
通过JS动态创建一个html DOM元素并显示
2014/10/15 Javascript
Javascript核心读书有感之语言核心
2015/02/01 Javascript
javascript三元运算符用法实例
2015/04/16 Javascript
javascript遇到html5的一些表单属性
2015/07/05 Javascript
jQuery实现在最后一个元素之前插入新元素的方法
2015/07/18 Javascript
学习javascript的闭包,原型,和匿名函数之旅
2015/10/18 Javascript
vue.js利用defineProperty实现数据的双向绑定
2017/04/28 Javascript
浅谈vue引入css,less遇到的坑和解决方法
2018/01/20 Javascript
vue 父组件调用子组件方法及事件
2018/03/29 Javascript
jQuery实现表单动态添加与删除数据操作示例
2018/07/03 jQuery
python中正则表达式的使用详解
2014/10/17 Python
Python文件及目录操作实例详解
2015/06/04 Python
Python函数式编程指南(四):生成器详解
2015/06/24 Python
Python 使用PIL numpy 实现拼接图片的示例
2018/05/08 Python
应用OpenCV和Python进行SIFT算法的实现详解
2019/08/21 Python
解决python彩色螺旋线绘制引发的问题
2019/11/23 Python
python3 Scrapy爬虫框架ip代理配置的方法
2020/01/17 Python
Python文件时间操作步骤代码详解
2020/04/13 Python
keras的三种模型实现与区别说明
2020/07/03 Python
Keras 中Leaky ReLU等高级激活函数的用法
2020/07/05 Python
详解pycharm2020.1.1专业版安装指南(推荐)
2020/08/07 Python
巴西最好的男鞋:Rafarillo
2018/05/25 全球购物
c/c++某大公司的两道笔试题
2014/02/02 面试题
综合素质自我评价评语
2015/03/06 职场文书
开学典礼观后感
2015/06/15 职场文书
初中班干部工作总结
2015/08/10 职场文书