자바스크립트의 복제 객체/함수 코드에 대한 자세한 설명

伊谢尔伦
풀어 주다: 2017-07-27 17:11:15
원래의
3076명이 탐색했습니다.

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. 사용자 정의 개체가 포함된 배열을 복제합니다.

으아아아

위 내용은 자바스크립트의 복제 객체/함수 코드에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!