国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

JS對象的深度克隆方法示例

2024-05-06 16:35:56
字體:
來源:轉載
供稿:網友

本文實例講述了JS對象的深度克隆方法。分享給大家供大家參考,具體如下:

js中創建的對象指向內存,所以在開發過程中,往往修改了一個對象的屬性,會影響另外一個對象。

尤其是在angular框架中,dom是由數據驅動的,在增刪改查對象的操作中,對象屬性的繼承關系是很讓人頭痛的!

我之前遇到的問題就是,在編輯頁面,操作了對象數據,影響到了展示數據的展現!

我整理了兩種深度克隆對象的方法,供大家參考!

首先var 一個假數據

復制代碼 代碼如下:
var schedule = {"status":21,"msg":"ok","data":[{"name":"lemon","age":21,"contactList":{"phone":[152,153,154],"email":5295}},{"name":"lara","age":22,"contact":{"phone":152,"email":5295}}]}

 

方法1:

遍歷自身,判斷當前對象是obj還是list,克隆出新對象

function deepClone(obj){  var o,i,j,k;  if(typeof(obj)!="object" || obj===null)return obj;  if(obj instanceof(Array))  {    o=[];    i=0;j=obj.length;    for(;i<j;i++)    {      if(typeof(obj[i])=="object" && obj[i]!=null)      {        o[i]=arguments.callee(obj[i]);      }      else      {        o[i]=obj[i];      }    }  }  else  {    o={};    for(i in obj)    {      if(typeof(obj[i])=="object" && obj[i]!=null)      {        o[i]=arguments.callee(obj[i]);      }      else      {        o[i]=obj[i];      }    }  }  return o;}var scheduleClone = deepClone(schedule)scheduleClone.data[0].contactList.phone[0] = 99999999999console.log('方法1 深度克隆')console.log(scheduleClone)console.log(JSON.stringify(schedule))console.log(JSON.stringify(scheduleClone))

方法2:

用js原生的json序列化的方式,簡單粗暴!

var scheduleClone2 = JSON.parse(JSON.stringify(schedule));console.log('方法2 深度克隆')console.log(scheduleClone2)scheduleClone2.data[0].contactList.phone[0] = 8888888console.log(JSON.stringify(schedule))console.log(JSON.stringify(scheduleClone2))

希望本文所述對大家Javascript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 阿克| 独山县| 武强县| 河东区| 永嘉县| 盘山县| 临江市| 运城市| 青岛市| 陕西省| 雷州市| 商丘市| 彰化县| 青浦区| 江门市| 莲花县| 东兰县| 习水县| 晋宁县| 衡山县| 合肥市| 通化县| 册亨县| 四川省| 静乐县| 德昌县| 济阳县| 阿巴嘎旗| 和顺县| 聂拉木县| 长寿区| 察隅县| 大埔县| 利川市| 津市市| 延津县| 涟水县| 鄯善县| 雷州市| 乐都县| 宣城市|