jquery中$.proxy及wrap()方法使用教程
对于jquery中的$.proxy及wrap()方法小编几乎没有使用过了,我相信各位朋友和小编一样不太理解$.proxy及wrap()方法的用法吧,下面我们就一起来看看。
我今天主要说下jquery中$.proxy及wrap()的使用,因为这两个我用的比较少,今天在项目中应用了,所以拿出来说一下!
jquery中$.proxy
jQuery.proxy( function, context )
function将要改变上下文语境的函数。
context函数的上下文语境(`this`)会被设置成这个 object 对象。
jQuery.proxy( context, name )
context函数的上下文语境会被设置成这个 object 对象。
name将要改变上下文语境的函数名(这个函数必须是前一个参数 ‘context’ 对象的属性)
我们先看个例子:
- //正常的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(),接受一个函数,然后返回一个新函数,并且这个新函数始终保持了特定的上下文(context )语境。
有两种语法:
- 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);
- });
例子,不过总算明白了proxy的用法了;
- <input type="button" value="测试" id="guoBtn" name="我是按钮的name"/>
- var obj = {
- name: "我是obj的name",
- sayName: function () {
- alert(this.name);
- }
- }
- $("#guoBtn").click(obj.sayName); //我是按钮的name
- // 如果我想访问obj的name怎么办呢?
- $("#guoBtn").click($.proxy(obj.sayName,obj));//"我是obj的name"
- $("#guoBtn").click($.proxy(obj, "sayName")); //"我是obj的name"
从上面proxy(a,b)的用法可以看出他的参数有两种写法.
第一种:a是一个function函数,b是这个函数的对象所有者.
第二种:a是一个对象,b是一个字符串,是a的属性名.
还有这个实例就是<>上的一个例子了.
- <div id="panel" style="display:none;">
- <button>Close</button>
- </div>
- $("#panel").fadeIn(function () {
- $("#panel button").click(function () {
- $(this).fadeOut();
- });
- });
button虽然消失了,但是panel却没有消失.可以使用proxy来解决这个问题.
- $("#panel").fadeIn(function () {
- var obj = this;
- $("#panel button").click($.proxy(function () {
- $(this).fadeOut();
- }, obj));
- });
这样单击按钮之后,panel才会消失.
个人感觉proxy最主要就是用来修改函数执行时的上下文对象的.
jquery中wrap()方法
wrap(),顾名思义,就是包裹的意思,就是在你所在器外层包裹一层东西。
- <div class="container">
- <div class="inner">Hello</div>
- <div class="inner">Goodbye</div>
- </div>
- $( ".inner" ).wrap(function() {
- return "<div class='" + $( this ).text() + "'></div>";
- });
结果如下:
- <div class="container">
- <div class="Hello">
- <div class="inner">Hello</div>
- </div>
- <div class="Goodbye">
- <div class="inner">Goodbye</div>
- </div>
- </div>
类似的用法还有.wrapAll()、.wrapInner()、.unwrap()等等!
jquery好多方法,关键看你运用的熟练程度,在做dom操作的时候,尽量用最简单,最有效的方法