jquery.extend和jquery.fn.extend的区别

jquery.extend
jquery.extend(),是拓展jquery这个类,即可以看作是jquery这个类本身的静态方法,例如:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title>简单插件学习一</title>
    <script src="../../Script/jquery.js"></script>
</head>
<body>
    <input type="text" id="txtName" />
    <script type="text/javascript">
       ;(function ($) {
            $.extend({
                test: function () {
                    alert("这是我测试的方775法3哈");
                }
            });
        })(jQuery);
       
       
       $.test();
      // $("#txtName").test();//不可以调用 
    </script>
</body>
</html>

即通过$.extend,扩充了Jquery本身,例如jquery上增加了test方法,只能其本身可以调用,跟具体的实例化对象没有一点关系,所以不可以用对象(具体的Dom节点)去调用。

jquery.fn.extend
从字面理解这个方法,就是拓展了jquery.fn的方法,而jquery.fn是啥玩意了 ,源码如下:

jQuery.fn = jQuery.prototype = {
    // The current version of jQuery being used
    jquery: version,

    constructor: jQuery,

    // Start with an empty selector
    selector: "",

    // The default length of a jQuery object is 0
    length: 0,

    toArray: function() {
        return slice.call( this );
    },
     //.......
}

jquery.fn=jquery.prototype,就是原型,jquery.fn.extend扩展的就是jquery对象(原型的)方法,对象是啥?就是类的实例化 ,例如:$("#txtName"),就是jquery的对象

也就是说,jquery.fn.extend拓展方法,要用在jquery对象上才行,一般插件的制作是用此方法进行扩展的。例如:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title>简单插件学习一</title>
    <script src="../../Script/jquery.js"></script>
</head>
<body>
    <input type="text" id="txtName" />
    <script type="text/javascript">
       ;(function ($) {
            $.extend({
                test: function () {
                    alert("这是我测试的方775法3哈");
                }
            });

            $.fn.test2 = function () {
                alert("这是我的方法3的");
                $.fn.test2.sn.add();
            }

            $.fn.test2.sn = {
                defaults: {
                    dir: "H",
                    speed: 500
                },

                add: function () {
                    alert("滚动方式:" + this.defaults.dir);
                }
            }

        })(jQuery);
       
       
       $.test();
      $("#txtName").test2();
    </script>
</body>
</html>

jquery.extend()方法主要用于扩展全局函数,例如$.ajax这种,例如上面代码中的test方法,只可以通过jquery本身去调用即:$.test(), 而不可以通过 jquery 对象去调用。

jquery.fn.extend(),大部分插件都是用此方法的 ,例如:$("#txtName").test2();

除此之外,我们写jquery插件,还经常遇到一些参数传递的问题,这些一般都是通过jquery.extend方法传递的 ,下面我们就一起去了解一下,例如:

$.extend(dest,src1,src2,src3....)

它的含义是将src1,src2,src3等合并到dest中,并返回到dest,但是 合并之后改变dest的结果,所以一般推荐以下方式:

var setting=$.extend({},src1,src2,src3);//也就是用{}作为dest的参数

例如:

 var setting = $.extend({}, { name: "alice", age: 28 }, { name: "stone", sex: "boy" });
 console.log(setting);

后面的参数如果和前面的参数存在相同的名称,则会覆盖前面的参数值,合并后的 结果为:



例如插件中一般用到的此方法:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <title>简单插件学习一</title>
    <script src="../../Script/jquery.js"></script>
</head>
<body>
    <input type="text" id="txtName" />
    <script type="text/javascript">
       ;(function ($) {
            $.fn.test2 = function (settings) {
                settings = $.extend({}, $.fn.test2.sn.defaults, settings);
                console.log(settings);
                $.fn.test2.sn.add();
            }

            $.fn.test2.sn = {
                defaults: {
                    dir: "H",
                    speed: 500
                },

                add: function () {
                    alert("滚动方式:" + this.defaults.dir);
                }
            }

        })(jQuery);
       
       $("#txtName").test2({name:"alicetest",dir:"V"});
    </script>
</body>
</html>

设置默认值,如果插件的传入的参数中存在此参数,则覆盖默认值,否则则使用默认值,例如上面的例子中输出结果为:


jquery的extend的重载原型

extend(boolean,dest,src1,src2,src3...);

其中第一个参数boolean代表是否进行深度拷贝,其余参数和之前一样,例如:

  var result = $.extend(true, {}, { name: "alice", location: { city: "shanghai", country: "china" } }, { age: 28, name: "stone", location: { city: "beijing", state: "y" } });
        console.log(result);

返回的结果为:



也就是 它会将src中的嵌套子对象也进行合并,即:location:{city:"beijing",country:"china",state:"y"}

如果将第一个参数传为false,效果又如何了,例如:

var result2 = $.extend(false, {}, { name: "alice",last:"222", location: { city: "shanghai", country: "china" } }, { age: 28, name: "stone", location: { city: "beijing", state: "y" } });
        console.log(result2);

结果如下:



只会进行合并,不会再对嵌套的子对象进行合并,例如;location:{city:"beijing",state:"y"}

常用的扩展实例,例如:

$.extend($.net,{
   hello:function(){
      alert("这是全局对象拓展一个scroll命名空间");
   }
});

这是将hello方法拓展到之前的jquery的net命名空间去,怎么调用??

例如,拓展动画中的$.easing:

$.extend($.easing,{
        easeInSine: function (x, t, b, c, d) {
            return -c * Math.cos(t/d * (Math.PI/2)) + c + b;
        }
    });

jQuery API 文档中可以知道,jQuery自定义动画的函数.animate( properties [, duration] [, easing] [, complete] )有四个参数,以上代码是拓展了jquery.easing 中的easeInSine动画,

如果不拓展jquery.easing,则需要引入整个jquery.easing.1.3.js,因此为了减少代码的冗余,我们可以扩展$.easing中的方法;

具体调用如下:

$("#imgSrc").animate({
            width: "90%",
            height: "100%",
            fontSize: "10em",
            borderWidth: 10
        }, "slow", "easeInSine", function () {
            alert("移动了吗 ,哈哈");
        });

原文地址:https://www.cnblogs.com/alice626/p/5248935.html

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,701评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,649评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,037评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,994评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,018评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,796评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,481评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,370评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,868评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,014评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,153评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,832评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,494评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,039评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,156评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,437评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,131评论 2 356