JS對象復(fù)制(深拷貝和淺拷貝)
一、淺拷貝
1、Object.assign(target,source,source...)
a、可支持多個對象復(fù)制
b、如果source和target屬性相同 source會復(fù)制target的屬性
c、target只能為Object對象
var obj = {a:1,b:2}
undefined
Object.assign({c:3},obj)
{c: 3, a: 1, b: 2}
obj
{a: 1, b: 2}
兼容性寫法if(Object.assign){//兼容}else{//不兼容}
2、擴展運算符(spread)
支持將多個對象復(fù)制到一個對象上“
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=10
10
objs
{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}
undefined
var objs = JSON.parse(JSON.stringify(obj))
undefined
objs
{a: 1, b: Array(3), c: {…}, bool: false}
objs.bool = true
true
objs
{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對象復(fù)制(深拷貝和淺拷貝)的詳細內(nèi)容,更多關(guān)于JS的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
HTML5+JS+JQuery+ECharts實現(xiàn)異步加載問題
這篇文章主要介紹了HTML5+JS+JQuery+ECharts實現(xiàn)異步加載問題,需要的朋友可以參考下2017-12-12
Javascript attachEvent傳遞參數(shù)的辦法
找了半天找到的解決辦法,看介紹說是javascript的閉包問題,導(dǎo)致得不能直接讀取外部的那個函數(shù),不然就所有傳遞的參數(shù)都變?yōu)樽詈笠粋€了。2009-12-12
javascript模板方法模式和職責(zé)鏈模式實例分析
這篇文章主要介紹了javascript模板方法模式和職責(zé)鏈模式,結(jié)合實例形式較為詳細的分析了模板方法模式和職責(zé)鏈模式基本原理、實現(xiàn)方法與相關(guān)注意事項,需要的朋友可以參考下2023-07-07
Layui彈框中數(shù)據(jù)表格中可雙擊選擇一條數(shù)據(jù)的實現(xiàn)
這篇文章主要介紹了Layui彈框中數(shù)據(jù)表格中可雙擊選擇一條數(shù)據(jù)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
JS實現(xiàn)超精簡響應(yīng)鼠標顯示二級菜單代碼
這篇文章主要介紹了JS實現(xiàn)超精簡響應(yīng)鼠標顯示二級菜單代碼,可實現(xiàn)針對鼠標事件的響應(yīng)動態(tài)修改頁面元素屬性的功能,非常簡單實用,需要的朋友可以參考下2015-09-09

