이 글은 자바스크립트에서 객체를 복제하는 방법을 주로 소개합니다. 도움이 필요한 친구들이 참고할 수 있습니다.
개발 중에는 객체 간의 참조 관계를 중단하고 객체를 복제하려는 경우가 많습니다.
JavaScript에서 간단한 방법은 JSON 함수를 사용하여 개체를 문자열로 문자열화한 다음 이를 새 개체로 구문 분석하는 것입니다. 아니면 인터넷에서 코드를 검색해 보세요. 오픈 소스 커뮤니티에는 여전히 복제 코드가 많이 있습니다.
비록 코드는 찾을 수 있지만 모든 것은 항상 다른 사람의 것이며 손으로 코드를 배우는 것은 항상 끊임없는 주제입니다.
두 개의 복제 함수를 직접 작성했습니다.
cloneOwn: 상속된 속성을 제외하고 사용자 정의 개체의 자체 속성을 복제합니다. 속성은 기본 데이터 유형 및 배열, 사용자 정의 개체일 수 있으며 지정할 수 있습니다. 복제할 속성 이름 목록입니다.
cloneArray: 배열을 복제합니다. 배열의 요소는 객체이거나 기본 유형일 수 있습니다.
//第一个参数是被克隆的对象,第二个参数是需要克隆的属性列表 function cloneOwn() { var obj = arguments[0]; if (typeof obj === 'undefined' || obj === null) return {}; if (typeof obj !== 'object') return obj; //第二个参数是属性名称列表,就采用该列表进行刷选 //否则就克隆所有属性 var attrs = arguments[1]; var enable_spec_attr = true; if (!(attrs instanceof Array)) { //console.log(attrs); attrs = obj; enable_spec_attr = false; } var result = {}; var i; for (i in attrs) { attr = enable_spec_attr? attrs[i]: i; //console.log(attr); if (obj.hasOwnProperty(attr)) { if (obj[attr] instanceof Array) { result[attr] = cloneArray(obj[attr]); } else if (typeof obj[attr] === 'object') { result[attr] = cloneOwn(obj[attr]); } else { result[attr] = obj[attr]; } } } return result; }
//克隆数组 function cloneArray(array) { if (typeof array === 'undefined' || array === null) return []; if (!(array instanceof Array)) return []; result = []; var i; for(i in array) { if (typeof array[i] !== 'object') { result[i] = array[i]; continue; } //clone object result[i] = cloneOwn(array[i]); } return result; }
호출
1. 사용자 정의 개체를 정기적으로 복제합니다.
var a = { name:'frank', age:20 }; var b= cloneOwn(a);
2. 복제의 속성을 지정합니다.
var a = { name:'frank', age:20, address:'any where' }; var b = cloneOwne(a, ['name', 'age']);
3. 배열 속성이 포함된 사용자 정의 개체 복제
var a = { name: 'kxh', age: 20, books: ['hai','ho','ali'], likes: [ {wname: 'kaili', wage: 81, fav: "aaaaa"}, {wname: 'seli', wage: 82, fav: "bbb"}, {wname: 'ailun', wage: 83, fav: "ccc"},] }; var b = cloneOwne(a);
4. 사용자 정의 개체가 포함된 배열 복제
var a = [ { name:'frank', age:20 }, { name:'leon', age:30 } ]; var b = cloneArray(a);
위 코드에는 여전히 많은 문제가 있습니다. as 와 같이 datatime 유형과 같은 내장 객체를 복제하는 데 몇 가지 문제가 있습니다.
문제 관리는 학습 과정입니다.