js 대상의 깊이 복제!

1381 단어 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

 
방법2:
js 원생의 json 서열화 방식으로 간단하고 거칠게!
var scheduleClone2 = JSON.parse(JSON.stringify(schedule));

console.log('  2     ')
console.log(scheduleClone2)
scheduleClone2.data[0].contactList.phone[0] = 8888888
console.log(JSON.stringify(schedule))
console.log(JSON.stringify(scheduleClone2))

좋은 웹페이지 즐겨찾기