为了账号安全,请及时绑定邮箱和手机立即绑定

vue中 实现对象的深拷贝

vue中 实现对象的深拷贝

慕森王 2019-03-13 17:15:49
自己定义了一个对象,因该对象要做双向数据绑定操作,因开发需要所以要备份一下该对象的初始状态,但是普通的备份对象无效仍然会因双向数据绑定而导致备份对象跟着改变,请教如何用深拷贝备份初始对象。
查看完整描述

4 回答

?
12345678_0001

TA贡献1802条经验 获得超5个赞

function deepClone(data){

       var type = getType(data);

       var obj;

       if(type === 'array'){

           obj = [];

       } else if(type === 'object'){

           obj = {};

       } else {

           //不再具有下一层次

           return data;

       }

       if(type === 'array'){

           for(var i = 0, len = data.length; i < len; i++){

               obj.push(deepClone(data[i]));

           }

       } else if(type === 'object'){

           for(var key in data){

               obj[key] = deepClone(data[key]);

           }

       }

       return obj;

   }


查看完整回答
反对 回复 2019-04-04
?
墨色风雨

TA贡献1853条经验 获得超6个赞

一般用 JSON.parse(JSON.stringify(data)) 就可以了。如果你要使用这种方式,有几个 注意事项 需要了解下


查看完整回答
反对 回复 2019-04-04
?
慕沐林林

TA贡献2016条经验 获得超9个赞

可以用lodash的cloneDeep函数。

狠一点就上immutable,facebook官方出的,所有数据都是不可变,不需要深拷贝之类的操作


查看完整回答
反对 回复 2019-04-04
?
浮云间

TA贡献1829条经验 获得超4个赞

纯数据对象的话可以用JSON的接口,

var obj_snapshot = JSON.parse(JSON.stringify(obj))

如果是带有function的js对象的话,那就。。。复杂点,写个克隆吧


查看完整回答
反对 回复 2019-04-04
  • 4 回答
  • 0 关注
  • 1782 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信