jQuery $.extend()用法总结

extend能实现的功能

将一个或多个对象的内容合并到目标对象。

语法:

$.extend( target [, object1 ] [, objectN ] );
$.extend( [deep ], target, object1 [, objectN ] )

  • deep: 可选。 Boolean类型 指示是否深度合并对象,默认为false。如果该值为true,且多个对象的某个同名属性也都是对象,则该"属性对象"的属性也将进行合并。
  • target: Object类型 目标对象,其他对象的成员属性将被附加到该对象上。
  • object1:可选。 Object类型 第一个被合并的对象。
  • objectN:可选。 Object类型 第N个被合并的对象。
    注意:
    1. 如果只为$.extend()指定了一个参数,则意味着参数target被省略。此时,target就是jQuery对象本身。通过这种方式,我们可以为全局对象jQuery添加新的函数。
    2. 如果多个对象具有相同的属性,则后者会覆盖前者的属性值。

举例:
$.extend(object1, object2); //object2 合并到 object1 中
多传几个参数:

    function test(target,obj1,obj2,obj3){
        $.extend(target,obj1,obj2,obj3);
        return target;
    };
    var target={
        name:'jack',
        sex:'male'
    };
    var obj1={
        name:"rose",
        age:20
    };
    var obj2={
        sex:'female',
        age:24
    };
    var obj3={
        bb:'you jump i jump'
    };
    console.log(test(target,obj1,obj2,obj3));
    //Object { name: "rose", sex: "female", age: 24, bb: "you jump i jump" }

这里我们传入了4个参数,然后返回第一个参数的值。从运行的得到结果我们可以看到,属性值永远是最后一个属性的值。
我们稍微修改一部分代码:

        var res=$.extend(target,obj1,obj2,obj3);
        return res;
结果返回依然是Object { name: "rose", sex: "female", age: 24, bb: "you jump i jump" }

所以$.extend()的返回值是第一个参数的值。
如果我们不想修改参数的值,我们可以把传入一个空对象:

$.extend({ },target,obj1,obj2,obj3);

为jQuery开发插件提供方法

如果只有一个参数提供给$.extend(),在这种情况下,jQuery对象本身被默认为目标对象。这样,我们可以在jQuery的命名空间下添加新的功能。这对于插件开发者希望向 jQuery 中添加新函数时是很有用的。

jQuery.extend(object):

为jQuery类本身添加类方法,可以理解为添加静态方法。

    $.extend({
        hello:function(){
            return "hello"+this._name;
        },
        _name:'jack'
    })
    console.log($._name,$.hello());
    //jack hellojack

jQuery.fn.extend(object);

给jQuery对象添加方法。。jQuery类的实例才可以调用这个“成员函数”。为什么呢我们先看:

jQuery.fn = jQuery.prototype = {
   init: function( selector, context ) {//….
//……
};

.fn属性是在原型上的,所以只有实例化出来的jQuery可以调用你extend里想添加的方法。
比如我们要开发一个插件,做一个特殊的编辑框,当它被点击时,便alert 当前编辑框里的内容。可以这么做:

$.fn.extend({
    alertWhileClick: function() {
        $(this).click(function() {
            alert($(this).val());
        });
    }
});
//$("#input1")是jQuery的实例,调用这个扩展方法
$("#input1").alertWhileClick();
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值