jQuery.proxy()
函数用于改变函数的上下文。
你可以将指定函数传入该函数,该函数将返回一个新的函数,其执行代码不变,但函数内部的上下文(this)已经被更改为指定值。
该函数属于全局的jQuery
对象。
语法
jQuery 1.4 新增该静态函数。jQuery.proxy()
函数有如下两种用法:
用法一:
jQuery.proxy( function, context [, additionalArguments ] )
将函数function
的上下文对象更改为指定的context
。
用法二:
jQuery.proxy( context, name [, additionalArguments ] )
将名为name
的函数的上下文更改为指定的context
。函数name
应是context
对象的一个属性。
参数
请根据前面语法部分所定义的参数名称查找对应的参数。
参数 | 描述 |
---|---|
function | Function类型需要更改上下文对象的函数。 |
context | 任意类型指定为函数设置的上下文对象。 |
name | String类型需要更改上下文对象的函数名称(它应该是context的一个属性)。 |
additionalArguments | 可选/任意类型指定调用该函数时需要传入的参数,参数可以有任意多个。 |
注意事项:
- 参数
additionalArguments
是从 jQuery 1.6 开始支持的。 - 该方法非常适用于在附加事件处理函数时,将事件处理函数的上下文指向另一个对象。此外,jQuery确保:即使你使用
jQuery.proxy()
返回的"代理"函数来绑定事件,如果你在解除绑定时传入原函数,jQuery仍然可以正确解除绑定。 - 从jQuery 1.9 开始,如果
context
为null或undefined,则"代理"函数的上下文不会发生更改。这将允许jQuery.proxy()
只传入函数的参数,而不更改函数的上下文。
返回值
jQuery.proxy()
函数的返回值为XMLDocument类型,返回解析后的XML文档对象。
示例&说明
以下是与jQuery.proxy()
函数相关的jQuery示例代码,以演示jQuery.proxy()
函数的具体用法:
//在当前页面内追加换行标签和指定的HTML内容 function w( html ){ document.body.innerHTML += "<br/>" + html; } var name = "Hello"; function foo( a, b ){ w( this.name ); w( a + b ); } // 直接调用 foo( 1, 2 ); // Hello // 3 var obj = { name: "CodePlayer", age: 18 }; var proxy = $.proxy( foo, obj, 5, 10 ); // 代理调用foo()函数,此时其内部的this指向对象obj proxy(); // CodePlayer // 15
36
1
我们认为:
用户的主要目的,是为了获取有用的信息,而不是来点击广告的。因此本站将竭力做好内容,并将广告和内容进行分离,确保所有广告不会影响到用户的正常阅读体验。用户仅凭个人意愿和兴趣爱好点击广告。
我们坚信:只有给用户带来价值,用户才会给我们以回报。
CodePlayer技术交流群1:
我们坚信:只有给用户带来价值,用户才会给我们以回报。
CodePlayer技术交流群1:

帮朋友打一个硬广告:
P2P网贷系统(Java版本) 新年低价大促销,多年P2P技术积累,系统功能完善(可按需定制,可支持第三方存管、银行存管),架构稳定灵活、性能优异、二次开发快速简单。 另可提供二次开发、安装部署、售后维护、安全培训等一条龙服务。
外行看热闹,内行看门道。可以自信地认为,在系统设计上,比市面上的晓风、迪蒙、方维、绿麻雀、国融信、金和盛等P2P系统要好。
深圳地区支持自带技术人员现场考察源代码、了解主要技术架构,货比三家,再决定是否购买。
也可推荐他人购买,一旦完全成交,推荐人可获得实际售价 10% 的返现。
有意向者,详情请 点击这里 联系,工作时间立即回复。