javascript - js 对象深拷贝和赋值
问题描述
代码中得到一个数组arr=[1,2,3];因为马上会被销毁,所以不能直接赋值给对象Obj.a,请问这种情况jquery如何写,使得arr销毁之后Obj.a=[1,2,3]?
问题解答
回答1:一般情况下很少会在 JS 中遇到“销毁”。然后,我不明白你所谓的立即销毁是指什么?
如果是指 delete arr,那么直接赋值也不会有问题,如下图:
如果你是要改变 arr 的内容。那么可以复制一个数组(有几种方法,concat 只是其中一种)
Obj.a = [].concat(arr);
如果确实需要深拷贝,jQuery.fn.clone(),不过貌似有一些限制。
如果其它数据,自己写深拷贝还是有点难度也比较麻烦,不如用 Lodash 的 cloneDeep()
回答2:拷贝数组:
利用 sliceobj.a = arr.slice();
obj.a = JSON.parse( JSON.stringify(arr));
没看懂你销毁的意思。。。。至于深拷贝:
function cloneObj(obj){ if( !obj || typeof obj == 'string' ){return obj; } else if ( obj instanceof Array ){return [].concat(obj); } else {var tempObj = {};for( var key in obj ){ tempObj[key] = cloneObj(obj[key]);}return tempObj; }}回答4:
如果你使用 ES2015 的话,可以使用对象展开运算符来拷贝。
obj.a = [...arr]
相关文章:
1. html - 移动端radio无法选中2. javascript - webpack打包后的bundlejs文件代码不知道什么意思.3. javascript - 关于ajax上传多图问题。4. JavaScript事件5. 正则表达式 - python pandas的sep参数问题6. javascript - 使用echarts做一个横向的柱状图,但是数据超出坐标轴范围了怎么办?7. javascript - 在静态页面上用load 引入的页面文件问题?8. css - 移动端 line-height安卓错位,苹果机正常用,缩放解决了,可是又出来了占位的问题9. javascript - Element UI表格错行10. javascript - es6模块加载export的输出值有点没太搞明白
