标签:ie8 rows object 50 兼容 var orgid 多维 cols
浅拷贝只是把对象的内存位置指针给拷贝了,若修改拷贝对象,则原对象也会跟踪修改。
var a = {a : 'old', b : { c : 'old'}}
var b = Object.assign({}, a)
b.a = 'new'
b.b.c = 'new'
console.log(a) // { a: 'old', b: { c: 'new' } }
console.log(b) // { a: 'new', b: { c: 'new' } } 改变b的时候a也跟着发生变化
以下是兼容ie8以下的多维数组深拷贝
function deepCopy(p, c) { c = c || {}; for (var i in p) { if (p.hasOwnProperty(i)) { if (typeof p[i] === 'object') { c[i] = (p[i] instanceof Array) ? [] : {}; deepCopy(p[i], c[i]); } else { c[i] = p[i]; } } } return c; } var CardViewData = [{rows: [40, 60], cols: [100], items: [ {rows: [100], cols: [30, 40, 30], items: [ {orgid: 1, object: {}}, {orgid: 2, object: {}}, {orgid: 3, object: {}} ]}, {rows: [100], cols: [50, 50], items: [ {rows: [50, 50], cols: [50, 50], items: [ {orgid: 4, object: {}}, {orgid: 5, object: {}}, {colspan: 2, orgid: 6, object: {}} ]}, {rows: [50, 50], cols: [100], items: [ {orgid: 7, object: {}}, {orgid: 8, object: {}} ]} ]}, ]}]; var mydeep = deepCopy(CardViewData) console.log(JSON.stringify(mydeep))
标签:ie8,rows,object,50,兼容,var,orgid,多维,cols 来源: https://www.cnblogs.com/hpx2020/p/10967970.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。