1、认识jQuery extend()和jQuery.fn.extend()

jQuery的API手册中,extend方法挂载在jQuery和jQuery.fn两个不同对象上方法,但在jQuery内部代码实现的是相同的,只是功能却不太一样;

且看官方给出解释:

jQuery.extend(): Merge the contents of two or more objects together into the first object.(把两个或者更多的对象合并到第一个当中);

jQuery.fn.extend():Merge the contents of an object onto the jQuery prototype to provide new jQuery instance methods.(把对象挂载到jQuery的prototype属性,来扩展一个新的jQuery实例方法)

2、理解jQuery.extend() 

我们先把jQuery看成了一个类,这样好理解一些。jQuery.extend(),是扩展的jQuery这个类。

假设我们把jQuery这个类看成是人类,能吃饭能喝水能跑能跳,现在我们用jQuery.extend这个方法给这个类拓展一个能说话speak()的技能。这样的话,不论是男人,女人,xx人.....等能继承这个技能(方法)了。

可以如下图这样写着:

  1. JQuery.extend({
  2. speak:function(){
  3. alert("how are you!");
  4. }
  5. });
调用方法如下:
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>jQuery.extend()与jQuery.fn.extend()区别</title>
  5. <meta charset="utf-8">
  6. <script type="text/javascript" src="jquery-1.7.1.js"></script>
  7. <script type="text/javascript">
  8. (function($){
  9. $.extend({
  10. speak:function(){
  11. alert("how are you!");
  12. }
  13. });
  14. })(jQuery);
  15. </script>
  16. <script type="text/javascript">
  17. $(document).ready(function(){
  18. $.speak();
  19. })
  20. </script>
  21. </head>
  22. <body>
  23.  
  24. </body>
  25. </html>

这说明$.speak)变成了jQuery这个类本身的方法(object),他现在能"说话"了。

但是吧,这个能力啊,只有代表全人类的 jQuery 这个类本身,才能用啊。你个人想用,你张三李四王五麻六,你个小草民能代表全人类嘛?

所以啊,这个扩展也就是所谓的静态方法,只跟这个 类 本身有关。跟你具体的实例化对象是没关系的。

 3、理解 jQuery.fn.extend()

从字面理解嘛,这个拓展的是jQuery.fn的方法。jQuery.fn是啥玩意呢?

  1. jQuery.fn = jQuery.prototype = {
  2. init:funtion(selector,context){
  3. //.....
  4.  
  5. }
  6. }

所以jQuery.fn.extend拓展的是jQuery对象(原型的)的方法啊!

对象是啥?就是类的实例化嘛,例如$("#abc") ,$(div)

那就是说,jQuery.fn.extend拓展的方法,你得用在jQuery对象上面才行啊!他得是张三李四王五痳六这些实例化的对象才能用啊。

说白了就是得这么用(假设xyz()是拓展的方法):

$('selector').xyz();

调用方法如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>jQuery.extend()与jQuery.fn.extend()区别</title>
  5. <meta charset="utf-8">
  6. <script type="text/javascript" src="jquery-1.7.1.js"></script>
  7. <script type="text/javascript">
  8. (function($){
  9. $.fn.extend({
  10. speak:function(){
  11. alert("how are you!");
  12. }
  13. });
  14. })(jQuery);
  15. </script>
  16. <script type="text/javascript">
  17. $(document).ready(function(){
  18. $("div").speak();
  19. })
  20. </script>
  21. </head>
  22. <body>
  23.  
  24. </body>
  25. </html>

4、两者区别总结:

4.1、两者调用方式不同:

jQuery.extend(),一般由传入的全局函数来调用,主要是用来拓展个全局函数,如$.init(),$.ajax();

jQuery.fn.extend(),一般由具体的实例对象来调用,可以用来拓展个选择器,例如$.fn.each();

4.2、两者的主要功能作用不同:

jQuery.extend(object); 为扩展jQuery类本身,为自身添加新的方法。

jQuery.fn.extend(object);给jQuery对象添加方法

4.3、大部分插件都是用jQuery.fn.extend()

 5、JQuery的extend扩展方法:

5.1、Jquery的扩展方法原型是:

  1. extend(dest,src1,src2,src3...);
         它的含义是将src1,src2,src3...合并到dest中,返回值为合并后的dest,由此可以看出该方法合并后,是修改了dest的结构的。
         如果想要得到合并的结果却又不想修改dest的结构,可以如下使用:
  1. var newSrc=$.extend({},src1,src2,src3...)//也就是将"{}"作为dest参数。

这样就可以将src1,src2,src3...进行合并,然后将合并结果返回给newSrc了。如下例:

  1. var result=$.extend({},{name:"Tom",age:21},{name:"Jerry",sex:"Boy"})
  2. 那么合并后的结果: result={name:"Jerry",age:21,sex:"Boy"}

也就是说后面的参数如果和前面的参数存在相同的名称,那么后面的会覆盖前面的参数值。

5.2、省略dest参数
           上述的extend方法原型中的dest参数是可以省略的,如果省略了,则该方法就只能有一个src参数,而且是将该src合并到调用extend方法的对象中去,如:
   5.2.1、$.extend(src)
   该方法就是将src合并到jquery的全局对象中去,如:

  1. $.extend({
  2. hello:function(){alert('hello');}
  3. });

就是将hello方法合并到jquery的全局对象中。

  5.2.2、$.fn.extend(src)
   该方法将src合并到jquery的实例对象中去,如:

  1. $.fn.extend({
  2. hello:function(){alert('hello');}
  3. });

就是将hello方法合并到jquery的实例对象中。

  下面例举几个常用的扩展实例:

  1. $.extend({net:{}});

这是在jquery全局对象中扩展一个net命名空间。

  1. $.extend($.net,{
  2. hello:function(){alert('hello');}
  3. })

这是将hello方法扩展到之前扩展的Jquery的net命名空间中去。

  5.2.3、Jquery的extend方法还有一个重载原型:

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

第一个参数boolean代表是否进行深度拷贝,其余参数和前面介绍的一致,什么叫深层拷贝,我们看一个例子:

  1. var result=$.extend( true, {},
  2. { name: "John", location: {city: "Boston",county:"USA"} },
  3. { last: "Resig", location: {state: "MA",county:"China"} }
  4. );

我们可以看出src1中嵌套子对象location:{city:"Boston"},src2中也嵌套子对象location:{state:"MA"},第一个深度拷贝参数为true,那么合并后的结果就是:

  1. var result={
  2. name:"John",last:"Resig", location:{city:"Boston",state:"MA",county:"China"}
  3. }

也就是说它会将src中的嵌套子对象也进行合并,而如果第一个参数boolean为false,我们看看合并的结果是什么,如下

  1. var result=$.extend( false, {},
    { name: "John", location:{city: "Boston",county:"USA"} },
  2. { last: "Resig", location: {state: "MA",county:"China"}
    });

那么合并后的结果就是:

  1. var result={
  2. name:"John",last:"Resig",location:{state:"MA",county:"China"}
  3. }

以上就是$.extend()在项目中经常会使用到的一些细节。

jQuery extend()和jQuery.fn.extend()区别和详解的更多相关文章

  1. JQuery在循环中绑定事件的问题详解

    JQuery在循环中绑定事件的问题详解 有个页面上需要N个DOM,每个DOM里面的元素ID都要以数字结尾,比如说 ? 1 2 3 <input type="text" nam ...

  2. Windows8 各种版本区别对比详解

    微软的 Windows8 操作系统提供了4个不同的版本,分别是 Windows RT.Windows 8 标准版.Windows 8 Pro 专业版 以及 Windows 8 Enterprise 企 ...

  3. java中4种修饰符访问权限的区别及详解全过程

    java中4种修饰符访问权限的区别及详解全过程 http://jingyan.baidu.com/article/fedf0737700b3335ac8977ca.html java中4中修饰符分别为 ...

  4. Java日志管理:Logger.getLogger()和LogFactory.getLog()的区别(详解Log4j)

    Java日志管理:Logger.getLogger()和LogFactory.getLog()的区别(详解Log4j) 博客分类: Java综合   第一.Logger.getLogger()和Log ...

  5. 《手把手教你》系列技巧篇(二十七)-java+ selenium自动化测试- quit和close的区别(详解教程)

    1.简介 尽管有的小伙伴或者童鞋们觉得很简单,不就是关闭退出浏览器,但是宏哥还是把两个方法的区别说一下,不然遇到坑后根本不会想到是这里的问题. 2.源码 本文介绍webdriver中关于浏览器退出操作 ...

  6. 区别和详解:jQuery extend()和jQuery.fn.extend()

    1.认识jQuery extend()和jQuery.fn.extend() jQuery的API手册中,extend方法挂载在jQuery和jQuery.fn两个不同对象上方法,但在jQuery内部 ...

  7. jquery中方法扩展 ($.fn & $.extend) 学习笔记

    A.$.fn 1.$.fn.method() 函数为jQuery对象扩展一个属性和方法(主要用于扩展方法) :method 为自定义方法名 ($.fn 等效 $.prototype) $.fn.bor ...

  8. jQuery 请指出'$'和'$.fn'的区别?或者说出'$.fn'的用途。

    ---------------------------------------------------------------------------------- 我们先把jQuery看成了一个类, ...

  9. jQuery 请指出'$'和'$.fn'的区别?或者说出'$.fn'的用途。

    http://hi.baidu.com/chy0806css/item/acc52425099c30ff50fd87eb Jquery为开发插件提供了两个方法,分别是: $.extend(obj);$ ...

随机推荐

  1. JetBrains Quest 3

    起因 今天早上看了一篇博文: 此时的我:"哎,这等好事不等我!" 然后......我打开官方推特: "什么?最后的任务?" 于是就有了这篇文章 开始操作 1.神 ...

  2. 免费获取 Jetbrain 全家桶使用兑换码的正确姿势!

    自今年1月份以Jetbrain公司严厉打击旗下开发工具产品(如:IntelliJ IDEA.WebStorm.PyCharm等)的盗版破解以来.求新破解方式.分享新破解方法的帖子或信息经常可以在各技术 ...

  3. vue中的$props、$attrs和$listeners研究 [包装iview组件]

    $props:当前组件接收到的 props 对象.Vue 实例代理了对其 props 对象属性的访问. $attrs:包含了父作用域中不作为 prop 被识别 (且获取) 的特性绑定 (class 和 ...

  4. 「踩坑记」Android API 判断权限申请结果的闪退问题

    这几天尝试着用Android Studio写一个小工具的时候遇到了一个动态权限申请的问题.权限的申请使用的语句为: ActivityCompat.requestPermissions(this, ne ...

  5. [C#] 命令总线模式

    1 高内聚.低耦合 虽然已经毕业很多年了,但依然总是能记得,<软件工程>这门课的老师总是强调 "高内聚,低耦合". 这些年,在架构方面的技术发展方向,目标就是不断的拆分 ...

  6. Springboot使用Undertow

    Springboot使用Undertow Undertow 是红帽公司开发的一款基于 NIO 的高性能 Web 嵌入式服务器 Undertow的特点: 轻量级:它是一个 Web 服务器,但不像传统的 ...

  7. Delphi10.3的DBGrid中memo类型显示内容而不是(WIDEMEMO)

    1]连接好数据库,并显示: 2]增加所有字段: 3]添加事件: //    FDQuery1UserName: TWideMemoField; procedure TForm1.FDQuery1Use ...

  8. 108. Convert Sorted Array to Binary Search [Python]

    108. Convert Sorted Array to Binary Search Given an array where elements are sorted in ascending ord ...

  9. x86汇编指令集大全(带注释)

    X86和X87汇编指令大全(有注释) PUSH 压栈.POP 来说是出栈.入栈(push):---------- 一.数据传输指令 ---------------------------------- ...

  10. MySQL数据库升级

    当前不少系统的数据库依旧是MySQL5.6,由于MySQL5.7及MySQL8.0在性能及安全方面有着很大的提升,因此需要升级数据库.本文通过逻辑方式.物理方式原地升级来介绍MySQL5.6 升级至M ...