JS對象復制(深拷貝和淺拷貝)
a、可支持多個對象復制
b、如果source和target屬性相同 source會復制target的屬性
c、target只能為Object對象
var obj = {a:1,b:2}undefinedObject.assign({c:3},obj){c: 3, a: 1, b: 2}obj{a: 1, b: 2} 兼容性寫法if(Object.assign){//兼容}else{//不兼容}2、擴展運算符(spread)
支持將多個對象復制到一個對象上“
var obj1 = { foo: 'foo' };var obj2 = { bar: 'bar' }; var copySpread = { ...obj1, ...obj2 }; // Object {foo: 'foo', bar: 'bar'}copySpread {foo: 'foo', bar: 'bar'}var obj = {a:1,b:2,c:3}var objs = {...obj}objs{a: 1, b: 2, c: 3}objs.a=1010objs{a: 10, b: 2, c: 3}obj{a: 1, b: 2, c: 3}二、深拷貝1、使用對象序列化 JSON.stringify()和JSON.parse()
注意:此方法僅在原對象包含可序列化值類型且沒有任何循環(huán)引用時才有效。不可序列化值類型的一個例子是Date對象 -JSON.parse只能將其解析為字符串而無法解析回其原始的Date對象 或者對象中屬性值為function
var obj = {a:1,b:[1,2,3],c:{e:3},bool:false}undefinedvar objs = JSON.parse(JSON.stringify(obj))undefinedobjs{a: 1, b: Array(3), c: {…}, bool: false}objs.bool = truetrueobjs{a: 1, b: Array(3), c: {…}, bool: true}obj{a: 1, b: Array(3), c: {…}, bool: false}2、使用遞歸,對對象屬性進行判斷
function deepClone(obj) { var copy; // 如果 obj 是 null、undefined 或 不是對象,直接返回 obj // Handle the 3 simple types, and null or undefined if (null == obj || 'object' != typeof obj) return obj; // Handle Date if (obj instanceof Date) { copy = new Date(); copy.setTime(obj.getTime()); return copy; } // Handle Array if (obj instanceof Array) { copy = []; for (var i = 0, len = obj.length; i < len; i++) {copy[i] = clone(obj[i]); } return copy; } // Handle Function if (obj instanceof Function) { copy = function() { return obj.apply(this, arguments); } return copy; } // Handle Object if (obj instanceof Object) { copy = {}; for (var attr in obj) { if (obj.hasOwnProperty(attr)) copy[attr] = clone(obj[attr]); } return copy; } throw new Error('Unable to copy obj as type isn’t supported ' + obj.constructor.name);}
以上就是JS對象復制(深拷貝和淺拷貝)的詳細內(nèi)容,更多關于JS的資料請關注好吧啦網(wǎng)其它相關文章!
相關文章:
1. XML入門的常見問題(三)2. XML 非法字符(轉(zhuǎn)義字符)3. .NET Framework各版本(.NET2.0 3.0 3.5 4.0)區(qū)別4. CSS3實例分享之多重背景的實現(xiàn)(Multiple backgrounds)5. 關于html嵌入xml數(shù)據(jù)島如何穿過樹形結(jié)構關系的問題6. 前端html+css實現(xiàn)動態(tài)生日快樂代碼7. 不要在HTML中濫用div8. el-input無法輸入的問題和表單驗證失敗問題解決9. JSP取得在WEB.XML中定義的參數(shù)10. WMLScript的語法基礎
