国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

javascript中clone對(duì)象詳解

2024-05-06 16:11:21
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
這篇文章主要介紹了javascript中clone對(duì)象的方法,需要的朋友可以參考下
 
 

  開(kāi)發(fā)中,打斷對(duì)象間的引用關(guān)系,只想下個(gè)副本的情況無(wú)處不在,clone一個(gè)對(duì)象就在所難免了。

  JavaScript中,簡(jiǎn)單的方法就是用JSON函數(shù),將對(duì)象stringify成字符串,再parse成一個(gè)新對(duì)象。要么就是從網(wǎng)上搜個(gè)代碼,開(kāi)源社區(qū)里面clone的代碼還是有不少的。

  代碼雖然可以找得到,但,東西永遠(yuǎn)是別人的,動(dòng)手學(xué)著碼永遠(yuǎn)是個(gè)不變的主題。

  自己寫了兩個(gè)克隆的函數(shù):

  cloneOwn:克隆自定義對(duì)象的自有屬性,不包括繼承的屬性,屬性可以是基本數(shù)據(jù)類型和數(shù)組,自定義的對(duì)象,可以制定要克隆的屬性名稱列表。

  cloneArray: 克隆數(shù)組,數(shù)組內(nèi)的元素可以是對(duì)象,基本類型。

 

復(fù)制代碼代碼如下:

//第一個(gè)參數(shù)是被克隆的對(duì)象,第二個(gè)參數(shù)是需要克隆的屬性列表
function cloneOwn() {
  var obj = arguments[0];
  if (typeof obj === 'undefined' || obj === null)
      return {};
  if (typeof obj !== 'object')
      return obj;
  //第二個(gè)參數(shù)是屬性名稱列表,就采用該列表進(jìn)行刷選
  //否則就克隆所有屬性
  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;
}

 

 

復(fù)制代碼代碼如下:

//克隆數(shù)組
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;
}

 

調(diào)用

1.常規(guī)克隆自定義對(duì)象:

 

復(fù)制代碼代碼如下:

var a = {
    name:'frank',
    age:20
};
var b= cloneOwn(a);

 

2.指定克隆的屬性

 

復(fù)制代碼代碼如下:

var a = {
    name:'frank',
    age:20,
    address:'any where'
};
var b = cloneOwne(a, ['name', 'age']);

 

3.克隆內(nèi)含有數(shù)組屬性的自定義對(duì)象

 

復(fù)制代碼代碼如下:

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.克隆數(shù)組,內(nèi)含有自定義對(duì)象

 

復(fù)制代碼代碼如下:

var a = [
   {
      name:'frank',
      age:20
    },
    {
       name:'leon',
       age:30
     }
];
var b = cloneArray(a);

 

上面的代碼還是有很多問(wèn)題的,比如,內(nèi)置對(duì)象的克隆就存在點(diǎn)問(wèn)題,例如datatime類型。

問(wèn)題管問(wèn)題,這樣一個(gè)學(xué)習(xí)過(guò)程也是要有的。


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 景泰县| 体育| 龙门县| 衡阳县| 天水市| 抚州市| 两当县| 阳信县| 香格里拉县| 湖州市| 舒城县| 中牟县| 济源市| 无棣县| 新河县| 三原县| 安多县| 岚皋县| 邵武市| 黄浦区| 循化| 海安县| 亳州市| 天峨县| 盐池县| 瑞昌市| 河源市| 巫溪县| 疏附县| 南康市| 嘉定区| 张家口市| 富裕县| 女性| 巴塘县| 宁国市| 保靖县| 阿巴嘎旗| 贵定县| 同仁县| 青神县|