首頁 >web前端 >js教程 >javascript中clone物件詳解

javascript中clone物件詳解

PHPz
PHPz原創
2016-05-16 16:29:112379瀏覽

這篇文章主要介紹了javascript中clone物件的方法,需要的朋友可以參考下。

開發中,打斷物件間的引用關係,只想下個副本的情況無所不在,clone一個物件就在所難免了。

JavaScript中,簡單的方法就是用JSON函數,將物件stringify成字串,再parse成一個新物件。要嘛就是從網路搜尋程式碼,開源社群裡面clone的程式碼還是有不少的。

程式碼雖然可以找得到,但,東西永遠是別人的,動手學著碼永遠是個不變的主題。

自己寫了兩個克隆的函數:

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);

上面的程式碼還是有很多問題的,例如,內建物件的克隆就存在點問題,例如datatime類型。

問題管問題,這樣一個學習過程也是要有的。
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn