两行代码搞定js对象深浅拷贝
有一段时间没有更新博客了,忙于工作。2018年刚过去,今天来开启2018第一篇博文。好了,咱们步入正题。
先上代码
/**
* 遍历对象
* 1.判断是不是原始值
* 2.判断是数组还是对象
* 3.建立相应的数组或对象
* 递归
*/ var obj=
{
name:"aaa",
age:23,
hobby:["basketball","music","coding"],
lover:{
name:"aaa",
age:23,
hobby:["sleep","movie","eat"]
}
}
var obj1={}; function deepCopy(origin,target){
var target=target||{};//容错处理
for (var i in origin) {
if(origin.hasOwnProperty(i)){ //避免把原型上的属性遍历出来
if(typeof origin[i]=="object"){//先判断是引用值
if(origin[i] instanceof Array){//判断是数组
target[i]=[];
deepCopy(origin[i],target[i]);
}else{
target[i]={}; //判断是对象
deepCopy(origin[i],target[i]);
} }else{//原始值直接赋值
target[i]=origin[i];
}
}
} return target;//返回拷贝后的对象
} deepCopy(obj,obj1);
console.log(obj,obj1);
代码解释的很清楚,精简一下代码(核心代码就两行)
function deepCopy(origin,target){
    for (var i in origin) {
        var target=target||{};
        if(origin.hasOwnProperty(i)){
            //核心代码就两行
            typeof origin[i]=="object"?(origin[i] instanceof Array?deepCopy(origin[i],target[i]=[]):deepCopy(origin[i],target[i]={})):target[i]=origin[i];
        }
    }
    return target;
}
deepCopy(obj,obj1);
console.log(obj,obj1);
首先深复制和浅复制只针对像 Object, Array 这样的复杂对象的。简单来说,浅复制只复制一层对象的属性,而深复制则递归复制了所有层级。
新年新气象,祝大家都能在2018年完成自己的小目标。
两行代码搞定js对象深浅拷贝的更多相关文章
- jquery侧边折叠导航栏制作,两行代码搞定
		
jquery侧边折叠导航栏制作,两行代码搞定 //CSS*{margin: 0;padding: 0} ul{list-style: none} .menu li ul{display: none} ...
 - 两行代码搞定网站gzip压缩
		
网站使用gzip压缩的好处就不用多说了吧,自行脑补,来说一下如何使用nodejs实现gzip压缩,只需要两行代码,so ease. 通过nodejs实现gzip 需要用到的模块 compression ...
 - AJ学IOS(41)UI之核心动画 两行代码搞定3D转场
		
AJ分享,必须精品 效果: 代码: 其实代码很少,苹果都给封装好了 // 1.创建核心动画 CATransition *ca = [CATransition animation]; // 1.1动画过 ...
 - 两行代码搞定 JavaScript 的日期验证
		
我们通常在 JavaScript 中验证日期,基本的思路大概是,先判断年月日是否有效,再判断当月是否有当日,比如一些月份没有 31 日,平年二月没有 29.30 日,闰年二月没有 30 日等等. 偶然 ...
 - 两行代码搞定UITableView无数据无网络显示-b
		
不知是否有像我一样的,每次写TableView在监听网络和无数据源时逻辑处理提示视图都是一堆代码,很繁琐也很重复的垃圾代码(可能就只有我这样
 - JavaScript的8行代码搞定js文件引入问题
		
单页面的操作,免不了会有各种jsp的嵌套问题,一个操作页面里面可能涉及到几十甚至上百个jsp页面. 平常我们对用到的js文件的引入,都会放到index的header里面.如图: 但是,让我们思考三个问 ...
 - 两行代码搞定Android视图扩散切换效果
		
用最简单的方式来实现Android视图扩散切换效果. 一.概述 这两天时间动手撸了个视图扩散切换效果的控制器,API兼容至Android4.0,更方便我们在视图切换过程中有炫酷的过渡效果.本来是想实现 ...
 - 两行代码搞定UI主流框架
		
XCNavTab XCNavTab适用于快速搭建NavigationController和TabBarController相结合的框架 https://github.com/xiaocaiabc/XC ...
 - 5行js代码搞定导航吸顶效果
		
一.HTML布局 首先写HTML布局 <body> <div id="wrap"></div> </body> 二.CSS样式 给点 ...
 
随机推荐
- centos7添加虚拟IP
			
1.在网络配置文件中添加虚拟IP,vi /etc/sysconfig/network-scripts/ifcfg-eno16777736 TYPE="Ethernet" BOOTP ...
 - 【堆的启发式合并】【P5290】[十二省联考2019]春节十二响
			
Description 给定一棵 \(n\) 个节点的树,点有点权,将树的节点划分成多个集合,满足集合的并集是树的点集,最小化每个集合最大点权之和. Limitation \(1~\leq~n~\le ...
 - Java基础-数组常见排序方式
			
Java基础-数组常见排序方式 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 数据的排序一般都是生序排序,即元素从小到大排列.常见的有两种排序方式:选择排序和冒泡排序.选择排序的特 ...
 - textview 使drawable与text一起居中的textview,这里仅支持drawableleft
			
package cc.hent.www.ramo_cmedcial.CustomView; import android.content.Context; import android.graphic ...
 - Java并发编程原理与实战五:创建线程的多种方式
			
一.继承Thread类 public class Demo1 extends Thread { public Demo1(String name) { super(name); } @Override ...
 - js事件的捕获和冒泡阶段
			
讨论的主要是两个事件模型:IE事件模型与DOM事件模型 IE内核浏览器的事件模型是冒泡型事件(没有捕获事件过程),事件句柄的触发顺序是从ChildNode到ParentNode. <div id ...
 - git fatal: The remote end hung up unexpectedly 错误
			
使用git将本地项目添加到远程仓库报以下错误 $ git push -u origin master fatal: The remote end hung up unexpectedly | 11.0 ...
 - CSS中的选择器(笔记)
			
1.通配符选择器(*):通配符选择器是用来选择所有元素,也可以选择某个元素下的所有元素.所有浏览器都支持通配符选择器. ;;} .dome *{padding: 2px;} 2.元素选择器(Ele): ...
 - debian旧日笔记
			
18:45 2007-10-7 序 图形界面较好的Linux操作系统有三个主要的发行版本:RedHat, Debian, SuSE.自RedHat9后,RedHat以Fedora为名发行新的版本.仍然 ...
 - 基本控件文档-UISwitch属性
			
CHENYILONG Blog 基本控件文档-UISwitch属性 Fullscreen UISwitch属性 技术博客http://www.cnblogs.com/ChenYilong/ 新 ...