频道栏目
首页 > 资讯 > HTML/CSS > 正文

浅拷贝与深拷贝

17-05-25        来源:[db:作者]  
收藏   我要投稿

1.浅拷贝

var obj1 = {
    a : 10
}

function copy(obj){//浅拷贝

    var newObj = {};

    for(var attr in obj){
        newObj[attr] = obj[attr];
    }

    return newObj;
}

var obj2 = copy(obj1);

obj2.a = 20;

alert(obj1.a);//10

2.深拷贝

var obj1 = {
    a : {b : 10}
}

function deepCopy(obj){//深拷贝,我们使用递归的方法来实现

    //终止条件,即什么时候 obj 不是对象就可以返回了
    if(typeof obj != 'object'){
        return obj;
    }
    var newObj = {};

    for(var attr in obj){
        newObj[attr] = deepCopy(obj[attr]);
    }

    return newObj;
}

var obj2 = deepCopy(obj1);

obj2.a.b = 20;

alert(obj1.a.b);//10
相关TAG标签
上一篇:基于Threejs的全景图预览
下一篇:css3flex布局,文字超出显示省略号
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站