国产探花免费观看_亚洲丰满少妇自慰呻吟_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教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 晋州市| 石泉县| 阜平县| 嘉善县| 上蔡县| 大方县| 鹤岗市| 南和县| 长垣县| 讷河市| 慈利县| 海阳市| 龙山县| 东平县| 景宁| 安溪县| 九龙县| 莎车县| 临朐县| 迁西县| 贡觉县| 弋阳县| 连山| 隆昌县| 政和县| 竹溪县| 左贡县| 临汾市| 湄潭县| 邛崃市| 当涂县| 航空| 朝阳市| 东丰县| 定结县| 朝阳县| 宣恩县| 汉阴县| 高平市| 阿荣旗| 邵东县|