[jquery选择器]jquery中$.proxy及wrap()方法使用教程

更新时间:2019-11-20    来源:jquery    手机版     字体:

【www.bbyears.com--jquery】


我今天主要说下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的用法了;

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的属性名.

还有这个实例就是<<锋利的jQuery>>上的一个例子了.



 

$("#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(),顾名思义,就是包裹的意思,就是在你所在器外层包裹一层东西。


  Hello
  Goodbye

$( ".inner" ).wrap(function() {
  return "";
});
结果如下:


 
    Hello
 
 
    Goodbye
 

类似的用法还有.wrapAll()、.wrapInner()、.unwrap()等等!

jquery好多方法,关键看你运用的熟练程度,在做dom操作的时候,尽量用最简单,最有效的方法

本文来源:http://www.bbyears.com/wangyezhizuo/80264.html