亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript數(shù)組和對象的復(fù)制

 更新時(shí)間:2017年03月21日 08:37:01   作者:tonyinsh  
本篇文章主要介紹了JavaScript數(shù)組和對象的復(fù)制的相關(guān)知識。具有很好的參考價(jià)值。下面跟著小編一起來看下吧

一、數(shù)據(jù)類型

從狹義上來說,JS把所有的數(shù)據(jù)分成兩大類型:基本類型和引用類型,其中基本類型包括Undefined、Null、Boolean、Number和String,引用類型為Object,常用的Array、Date、RegExp、Function等都屬于Object類型。

基本型數(shù)據(jù)和引用型數(shù)據(jù)的區(qū)別之一就是,在復(fù)制變量時(shí),基本型數(shù)據(jù)復(fù)制獨(dú)立的一份新的拷貝,而引用型數(shù)據(jù)復(fù)制的是原變量的引用。下面是一個(gè)例子:

// 基本類型數(shù)據(jù)的復(fù)制
var a = 10;
var b = a; // b = 10
a = 20; // a = 20, b = 10
// 引用類型數(shù)據(jù)的復(fù)制
var m = [1, 2];
var n = m;
m[0] = 10;
console.log(n[0]); // 10

如果我想復(fù)制引用類型本身的值而非引用,顯然不能采用上面的方式。

二、數(shù)組的淺復(fù)制

淺復(fù)制是指對象(數(shù)組)被復(fù)制時(shí),其引用字段的值不會被復(fù)制,而是復(fù)制了對應(yīng)字段的引用。如:

var src = [
 'alpha',
 ['bravo', 'chalie']
];
var dest = [];
for (var i = 0; i < src.length; i++) {
 dest[i] = src[i];
}
//此時(shí),如果改變src中的引用字段,dest中相應(yīng)的字段也會被改變
src[1].push('delta');
console.log(dest[1]); // ['bravo', 'chalie', 'delta']

淺復(fù)制一般用于一維數(shù)組,即數(shù)組中不存在引用類型的情況。常用的淺復(fù)制方法有:

concat方法

 var src = ['alpha', 'bravo'],
  dest = [];
 dest = dest.concat(src);

concat方法更多地被用在數(shù)組合并中,比如:

 var a = ['alpha', 'bravo'],
  b = ['chalie', 'delta'],
  combine;
 combine = a.concat(b);

特別要指出,concat用于數(shù)組合并時(shí),是將兩個(gè)(或多個(gè))數(shù)組中的所有元素復(fù)制到新的對象,對于大型數(shù)組來說,開銷比較大。更好的辦法是把后一個(gè)數(shù)組的元素復(fù)制到前一個(gè)數(shù)組中:

 var src = ['alpha', 'bravo'],
  dest = ['chalie', 'delta'];
 Array.prototype.push.apply(src, dest);

slice方法

slice方法可以從已有數(shù)組中返回選定的元素,返回的是一個(gè)新數(shù)組。

 var src = ['alpha', 'bravo'],
 var dest = src.slice(0);

三、對象的淺復(fù)制

對象的淺復(fù)制可以用for-in遍歷來實(shí)現(xiàn),在es6中提供了更為方便的Object.assign()方法。

 var src = {name: 'fox', age: 20},
  dest = null;
 dest = Object.assign({}, src);

也可以使用jQuery中的$.extend,underscore中的_.extend等方法來實(shí)現(xiàn)對象的復(fù)制。

四、深度復(fù)制

淺復(fù)制的應(yīng)用場景有限,更多情況下,我們希望能夠?qū)ο髲?fù)制出一個(gè)完整的副本,這就需要用到typeof或instanof操作符來對各個(gè)字段的類型進(jìn)行判斷。如果某字段是基本類型的,可以直接復(fù)制。如果某字段是引用類型的,還需要對該字段的所有字段進(jìn)行上述判斷,這就很容易讓我們考慮使用遞歸來實(shí)現(xiàn)這個(gè)功能。

function deep_copy(src, dest) {
 for (var p in src) {
  if (Array.isArray(src[p]) || src[p] instanceof Object) {
   dest[p] = Array.isArray(src[p]) ? [] : {};
   arguments.callee(dest[p], src[p]);
  }else {
   dest[p] = src[p];
  }
 }
}

在上述代碼中,由于數(shù)組是特殊的對象,因此可以用for-in來遍歷。

另外,還可以使用json大法:

 function deep_copy_in_json(src) {
  return JSON.parse(JSON.stringify(src));
 }

這樣做雖然比較簡便,但原對象的很多屬性在操作后會丟失,比如construtor屬性以及對象原型中的一些方法。

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

  • javascript不同頁面?zhèn)髦档母倪M(jìn)版

    javascript不同頁面?zhèn)髦档母倪M(jìn)版

    改進(jìn)點(diǎn):支持同頁面有多個(gè)文本框,可自動向不同的文本框傳值。先看演示吧
    2008-09-09
  • Javascript Event(事件)的傳播與冒泡

    Javascript Event(事件)的傳播與冒泡

    本文主要介紹了Event(事件)的傳播與冒泡。具有很好的參考價(jià)值,下面跟著小編一起來看下吧
    2017-01-01
  • 小程序rich-text組件如何改變內(nèi)部img圖片樣式的方法

    小程序rich-text組件如何改變內(nèi)部img圖片樣式的方法

    這篇文章主要介紹了小程序rich-text組件如何改變內(nèi)部img圖片樣式的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-05-05
  • Array.prototype.slice.apply的使用方法

    Array.prototype.slice.apply的使用方法

    arguments在JavaScript語法中是函數(shù)特有的一個(gè)對象屬性(Arguments對象),用來引用調(diào)用該函數(shù)時(shí)傳遞的實(shí)際參數(shù)。
    2010-03-03
  • 最新評論