开发中常用的 $.extend 总结
工作中常见$.extend( ),所以就查了一些它的用法。
一、Jquery的扩展方法原型是:
extend(dest, src1, src2, src3...)
它的含义是将src1,src2,src3...合并到dest中,返回值为合并后的dest,由此可以看出该方法合并后,是修改了dest的结构的。如果想要得到合并的结果却又不想修改dest的结构,可以如下使用:
var newSrc = $.extend({}, src1, src2, src3...) //也就是将"{}"作为dest参数
这样就可以将src1, src2, src3...进行合并,然后将结果返回给newSrc。如:
var result = $.extend({}, {name: "Tom", age: 21}, {name: "Jerry", sex: "Boy"})
合并后的结果:
result = {name: "Jerry", age: 21, sex: "Boy"}
也就是说,如果后面的参数和前面的参数相同会覆盖。
二、省略dest参数
上述extend方法原型中的dest参数是可以省略的,如果省略了,则该方法就只能有一个src参数,而且是将src合并到调用extend方法的对象中去,如:
1. $.extend(src)
该方法就是将src合并到jquery的全局对象中去,如:
$.extend({hello: function(){alert('hello');}})
上述代码表示将hello方法合并到jquery的全局对象中。
2.$.fn.extend(src)
该方法将src合并到jquery的实例对象中去,如:
$.fn.extend({
    hello: function(){alert('hello');}
});
就是将hello方法合并到jquery的实例对象中。
3.常用扩展实例
● 在jquery全局对象中扩展一个net命名空间:
$.extend({net: {}});
● 将hello方法扩展到之前扩展的jquery的net命名空间中去。
$.extend($.net , {
    hello: function(){alert('hello');}
})
三、jquery的extend方法还有一个重载原型
extend(boolean , dest , src1 , src2 , src3...)
第一个参数boolean代表是否进行深度拷贝,其余参数和前面介绍的一致,什么叫深拷贝,我们看一个例子:
var result = $.extend(true , {},
    { name: "John", location: { city: "Boston", county: "USA"}},
    { last: "Resig", location: { state: "MA", county: "China"}});
我们可以看出src1中嵌套子对象location: {city: "Boston"}, src2中也嵌套子对象location:{state: "MA"},第一个深度拷贝参数为true,那么合并后的结果就是:
result = {name: "John", last: "Resig",
    location: {city: "Boston", state: "MA", county: "China"}}
也就是说它会将src中的嵌套子对象进行合并,而如果第一个参数boolean为false:
var result = $.extend(false, {},
    { name: "John", location: { city: "Boston", county: "USA"}},
    { last: "Resig", location: { state: "MA", county: "China"}})
那么合并后的结果是:
result = { name: "John", last: "Resig", location: { state: "MA", county: "China"}}
以上就是$.extend()在项目中经常会使用到的一些细节。
开发中常用的 $.extend 总结的更多相关文章
- .net开发中常用的第三方组件
		
.net开发中常用的第三方组件 2013-05-09 09:33:32| 分类: dotnet |举报 |字号 订阅 下载LOFTER 我的照片书 | RSS.NET.dll RSS. ...
 - 依赖注入及AOP简述(十)——Web开发中常用Scope简介 .
		
1.2. Web开发中常用Scope简介 这里主要介绍基于Servlet的Web开发中常用的Scope. l 第一个比较常用的就是Application级Scope,通常我们会将一 ...
 - spring注解开发中常用注解以及简单配置
		
一.spring注解开发中常用注解以及简单配置 1.为什么要用注解开发:spring的核心是Ioc容器和Aop,对于传统的Ioc编程来说我们需要在spring的配置文件中邪大量的bean来向sprin ...
 - Android源码浅析(四)——我在Android开发中常用到的adb命令,Linux命令,源码编译命令
		
Android源码浅析(四)--我在Android开发中常用到的adb命令,Linux命令,源码编译命令 我自己平时开发的时候积累的一些命令,希望对你有所帮助 adb是什么?: adb的全称为Andr ...
 - 2019-2-20C#开发中常用加密解密方法解析
		
C#开发中常用加密解密方法解析 一.MD5加密算法 我想这是大家都常听过的算法,可能也用的比较多.那么什么是MD5算法呢?MD5全称是 message-digest algorithm 5[|ˈmes ...
 - 开发中常用的es6知识
		
结合实际开发,开发中常用的es6的知识: 1.新增let和const命令: ES6 新增了let命令,用来声明变量.它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效: cons ...
 - Android开发中常用的库总结(持续更新)
		
这篇文章用来收集Android开发中常用的库,都是实际使用过的.持续更新... 1.消息提示的小红点 微信,微博消息提示的小红点. 开源库地址:https://github.com/stefanjau ...
 - iOS开发中常用的数学函数
		
iOS开发中常用的数学函数 /*---- 常用数学公式 ----*/ //指数运算 3^2 3^3 NSLog(,)); //result 9 NSLog(,)); //result 27 //开平方 ...
 - Struts2页面开发中常用标签使用说明
		
1. Struts2页面开发中常用标签使用说明 1.1.往action里传值的使用方式: <input name="userName" type="text&quo ...
 
随机推荐
- discuz 门户功能增加自定义keywords字段
			
discuz的门户的“发布文章”功能中,没有自动添加keywords字段,结果在文章页面中的meta的keywords中只显示标题,这样对于seo及其不利,今天整理了添加keywords字段方法. 一 ...
 - poj2236无线网络
			
这一题的大意:在救灾当中需要用网络,这堆人就用笔记本建了一个无线网,但是来,互相通信都是有距离限制的,一台电脑只能和距离他为d的电脑通信,然后一台电脑也可以通过几台电脑搭成线这样通信.然后就是输入每台 ...
 - CentOS安装Python教程
			
下载/安装python yum install -y bzip2* #nodejs 0.8.5需要,请安装python前,先安装此模块. wget http://www.python.org/ft ...
 - MongoDB服务安装
			
0.解压压缩包:D:\lab\mongodb 1.创建目录: D:\lab\mongodb\data D:\lab\mongodb\data\db D:\lab\mongodb\data\log D: ...
 - JS简单验证密码强度
			
<input type="password" id="password" value=""/><button id=&qu ...
 - Iveely Search Engine 0.4.0 的发布
			
千呼万唤始出来,Iveely Search Engine 0.4.0 的发布 经过无数个夜晚的奋战,以及无数个夜晚的失眠,Iveely Search Engine 0.4.0 终于熬出来了,这其中 ...
 - Quagga添加自己的命令
			
参考了王斌的文档:http://down.51cto.com/data/621454 TIP:笔者使用的版本是0.99.20 需求:在接口模式下添加一条"ip ospf enable&quo ...
 - Android 中单位讲解
			
1. dip(dp): device independent pixels(设备独立像素). dp也就是dip.这个和sp基本类似.如果设置表示长度.高度等属性时可以使用dp 或sp.但如果设置字体, ...
 - Android零点一度的区别——Matrix
			
2013-07-07 导语:Matrix是android中对图像绘制的处理(旋转.放缩.平移等等),貌似书本翻页就是用这种方式处理的 正文: 1.基于坐标(px,py)旋转degrees度, post ...
 - Android开发(19)---常见dialog对话框的运用
			
Dialog是android开发过程中最常用到的组件之一,Dialog的创立办法有两种: 一是直接new一个Dialog目标,然后调用Dialog目标的show和dismiss办法来操控对话框的显现和 ...