实例解析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 相关文章推荐
用js统计用户下载网页所需时间的脚本
Oct 15 Javascript
基于jquery1.4.2的仿flash超炫焦点图播放效果
Apr 20 Javascript
js过滤数组重复元素的方法
Sep 05 Javascript
Javascript拓展String方法小结
Jul 08 Javascript
js中switch case循环实例代码
Dec 30 Javascript
js实现简单选项卡与自动切换效果的方法
Apr 10 Javascript
通过node-mysql搭建Windows+Node.js+MySQL环境的教程
Mar 01 Javascript
使用 stylelint检查CSS_StyleLint
Apr 28 Javascript
基于Jquery插件Uploadify实现实时显示进度条上传图片
Mar 26 Javascript
关于vue.js弹窗组件的知识点总结
Sep 11 Javascript
bootstrapvalidator之API学习教程
Jun 29 Javascript
Vue+scss白天和夜间模式切换功能的实现方法
Jan 05 Vue.js
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过滤敏感词的示例
2014/03/31 PHP
PHP实现支持SSL连接的SMTP邮件发送类
2015/03/05 PHP
php+ajax无刷新分页实例详解
2015/12/07 PHP
PHP调用Mailgun发送邮件的方法
2017/05/04 PHP
仅IE9/10同时支持script元素的onload和onreadystatechange事件分析
2011/04/27 Javascript
JavaScript中将一个值转换为字符串的方法分析[译]
2012/09/21 Javascript
js汉字转拼音实现代码
2013/02/06 Javascript
JavaScript转换二进制编码为ASCII码的方法
2015/04/16 Javascript
jQuery插件实现带圆点的焦点图片轮播切换
2016/01/18 Javascript
nodejs修复ipa处理过的png图片
2016/02/17 NodeJs
javascript 判断是否是微信浏览器的方法
2016/10/09 Javascript
谈谈JavaScript中浏览器兼容问题的写法小议
2016/12/17 Javascript
鼠标点击input,显示瞬间的边框颜色,对之修改与隐藏实例
2016/12/26 Javascript
原生js实现淘宝购物车功能
2020/06/23 Javascript
Angular多选、全选、批量选择操作实例代码
2017/03/10 Javascript
jQuery实现拼图小游戏(实例讲解)
2017/07/24 jQuery
微信小程序onLaunch异步,首页onLoad先执行?
2018/09/20 Javascript
@angular前端项目代码优化之构建Api Tree的方法
2018/12/24 Javascript
详解JavaScript的this指向和绑定
2020/09/08 Javascript
初步理解Python进程的信号通讯
2015/04/09 Python
python处理大数字的方法
2015/05/27 Python
python实现文件助手中查看微信撤回消息
2019/04/29 Python
Jupyter notebook运行Spark+Scala教程
2020/04/10 Python
Python Dict找出value大于某值或key大于某值的所有项方式
2020/06/05 Python
requests在python中发送请求的实例讲解
2021/02/17 Python
CSS3实现简易版的刮刮乐效果
2016/09/27 HTML / CSS
针对HTML5的Web Worker使用攻略
2015/07/12 HTML / CSS
MIRTA官网:手工包,100%意大利制造
2020/02/11 全球购物
shallow copy和deep copy的区别
2016/05/09 面试题
在校生自我鉴定
2014/01/23 职场文书
《乡愁》教学反思
2014/02/18 职场文书
小学生演讲稿大全
2014/04/25 职场文书
小学生民族团结演讲稿
2014/08/27 职场文书
地震慰问信
2015/02/14 职场文书
SQL试题 使用窗口函数选出连续3天登录的用户
2022/04/24 Oracle
讲解Python实例练习逆序输出字符串
2022/05/06 Python