成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Javascript 中的 Array 操作

khs1994 / 549人閱讀

摘要:語法函數(shù)的幾個參數(shù)含義上一次執(zhí)行函數(shù)后返回的值當(dāng)前數(shù)組元素值當(dāng)前數(shù)組元素索引遍歷的數(shù)組對象第一次調(diào)用函數(shù)時,如果有值,則為,為數(shù)組第一個元素。

Javascript 中的 Array 操作

在各種語言中,數(shù)組總是一個比較重要的數(shù)據(jù)結(jié)構(gòu),Javascript 中的 Array 也不例外。Javascript 中的 Array 提供了一系列方法可以更好地讓我們操作 Array 中的元素,下面我們就來看看這些操作方法。

Array 之基本操作

在基本操作部分,我們約定,加粗的方法可以改變數(shù)組本身,其余方法不改變。

1、 Array 創(chuàng)建

利用字面量創(chuàng)建 Array (推薦): var arr = [];

利用 Array 對象創(chuàng)建 Array: var arr = new Array([length]);//可以指定數(shù)組長度,注意不是數(shù)組上限;

利用 Array 對象創(chuàng)建 Array: var arr = new Array(value1, value2, value3, …);
注意:Javascript 中 Array 中的元素不要求類型一致;

2、 Array 訪問元素

var value = arr[index];

Array.slice(start[, end]);//從 start 位置開始截取原數(shù)組至 end (不包括 end 位置),返回截取的數(shù)組。若省略 end ,則截取 start 位置后所有元素;

3、 Array 添加與刪除元素 在數(shù)組末尾添加或刪除元素:

Array.push(value1, value2, vlaue3, …);//將一個或多個元素附加在數(shù)組末尾,并返回新數(shù)組長度;

Array.pop();//移除數(shù)組最后一個值,并返回該元素值;

在數(shù)組開始添加或刪除元素:

Array.unshif(value1, value2, value3, …);//將一個或多個元素附加在數(shù)組開頭,原數(shù)組元素依次后移,并返回新數(shù)組長度;

Array.shift();//移除數(shù)組第一個值,并返回該元素值;

在任意位置添加或刪除元素:

Array.splice(pos, 0, value1, value2, value3, ...);//從數(shù)組 pos 位置開始刪除 0 個元素,并在刪除的位置插入value1, vlaue2, vlaue3…,并返回一個空數(shù)組;

Array.splice(pos, count);//從數(shù)組 pos 位置開始刪除 count 個元素,

4、 Array 合并

Array.concat(para);// para 可以為數(shù)組或元素值,也可以為兩者組合,將所有元素連接成一個數(shù)組,返回連接好的數(shù)組;

5、 Array 字符串化

Array.join(sperator);//返回由數(shù)組元素組成并由 seperator 分隔的字符串。若 seperator 為空,則默認(rèn)以 “,” 連接;

Array.toString()Array.toLocaleString();//返回由數(shù)組元素組成并由“,”分隔的字符串(不常用);兩種方法的區(qū)別在于 toLocaleString() 會轉(zhuǎn)變?yōu)楸镜丨h(huán)境字符串(如Date.toLocalString() 會轉(zhuǎn)化為當(dāng)?shù)貢r間格式的字符串),toString() 則轉(zhuǎn)為傳統(tǒng)字符串; Array 的這兩種方法用法無區(qū)別;

6、 Array 排序

Array.reverse();//顛倒數(shù)組中的元素;

Array.sort();//按字符編碼進(jìn)行排序,支持自定義排序函數(shù);

7、 Array 查找

indexOf()//返回第一個與給定參數(shù)相等的數(shù)組元素的索引,沒有找到則返回-1。

lastIndexOf()//返回在數(shù)組中搜索到的與給定參數(shù)相等的元素的最后(最大)索引。

8、 其他函數(shù)

Array.isArray();//判斷某個值是否為數(shù)組;

Array 之高級操作

首先介紹 Array 的 5 種迭代函數(shù)。這 5 種函數(shù)的特點是都有一個 callback 函數(shù),函數(shù)會為每一個數(shù)組元素調(diào)用一次 callback 函數(shù)??蛇x參數(shù)是 thisArg, 作為 callback被調(diào)用時的 this 值,如果沒有傳入 thisArg 值,則在非嚴(yán)格模式下將會是全局對象,嚴(yán)格模式下是 undefined。其中,callback 函數(shù)中包含三個參數(shù),分別是當(dāng)前元素的值、當(dāng)前元素索引和被遍歷的數(shù)組。這 5 種函數(shù)遍歷的元素個數(shù)在第一次調(diào)用 callback 函數(shù)時就已經(jīng)確定,即以后即使添加元素也不會改變遍歷次數(shù),未訪問到且被刪除的值不會被 callback 訪問到,未訪問到且被修改的元素被修改后,傳遞給 callback 的值是被修改后的值。

1、 Array.forEach()

遍歷并為每一項元素執(zhí)行一遍 callback 函數(shù)。是 5 個函數(shù)中唯一一個沒有返回值的函數(shù)。

var arr = [1, 2, 3];
arr.forEach(function(ele) {
    console.log(ele);
});

運行結(jié)果:

1
2
3
2、 Array.map()

遍歷并處理所有元素,返回由每個 callback 函數(shù)返回值組成的新數(shù)組。

var arr = [1, 2, 3];
var newArr = arr.map(function(ele) {
    return "element" + ele;
});
console.log(newArr);
console.log(arr);

運行結(jié)果:

["element1", "element2", "element3"]
[1, 2, 3]
3、 Array.filter()

遍歷所有元素,過濾掉不符合條件(即使得 callback 返回 false)的元素。

var arr = [1, 2, 3, 11, 12, 13];
var newArr = arr.filter(function(ele) {
    return ele > 10;
});
console.log(newArr);
console.log(arr);

運行結(jié)果:

[11, 12, 13]
[1, 2, 3, 11, 12, 13]
4、 Array.every()

遍歷所有元素,當(dāng)所有元素使得 callback 返回 true,則返回 true,否則返回 false。

var arr1 = [9, 12, 13];
var result1 = arr1.every(function(ele) {
    return ele > 10;
});

var arr2 = [11, 12, 13];
var result2 = arr2.every(function(ele) {
    return ele > 10;
});

console.log(arr1);
console.log("result1:" + result1);
console.log(arr2);
console.log("result2:" + result2);

運行結(jié)果:

[9, 12, 13]
result1:false
[11, 12, 13]
result2:true
5、 Array.some()

遍歷所有元素,只要找到一個元素使得 callback 返回 true,則返回 true,否則返回 false。

var arr1 = [1,3,5,7,9];
var result1 = arr1.some(function(ele) {
    return ele > 10;
});

var arr2 = [1,2,3,11];
var result2 = arr2.some(function(ele) {
    return ele > 10;
});

console.log(arr1);
console.log("result1:" + result1);
console.log(arr2);
console.log("result2:" + result2);

運行結(jié)果:

[1, 3, 5, 7, 9]
result1:false
[1, 2, 3, 11]
result2:true
6、 Array.reduce()

將數(shù)組中的元素從左到右進(jìn)行縮減,最終縮減為一個值。

Array.reduce()語法:

Array.reduce(function(previousValue, currentValue, index, array){

}, [initialValue]);

callback 函數(shù)的幾個參數(shù)含義:

previousValue:上一次執(zhí)行 callback 函數(shù)后返回的值

currentValue:當(dāng)前數(shù)組元素值

index:當(dāng)前數(shù)組元素索引

array:遍歷的數(shù)組對象

第一次調(diào)用 callback 函數(shù)時,如果 initialValue 有值,則 previousValue 為 initialValue,
currentValue 為數(shù)組第一個元素。否則 previousValue 為數(shù)組第一個元素,currentValue 為數(shù)組第二個元素。

var arr = ["a", "b", "c"];
arr.reduce(function(pre, cur, ind, array) {
    console.log(ind);
});

運行結(jié)果:

1
2

再看另一個有 initialValue 的例子:

var arr = ["a", "b", "c"];
arr.reduce(function(pre, cur, ind, array) {
    console.log(ind);
}, "z");

運行結(jié)果是:

0
1
2

隨著 ES6 的誕生,Array 出現(xiàn)了更多的方法??紤]到瀏覽器的兼容性,在使用下面的方法時需要注意所使用的瀏覽器是否支持。

7、Array.from()

將一個類數(shù)組對象或可迭代對象轉(zhuǎn)換成真實的數(shù)組。

類數(shù)組對象: 擁有一個 length 屬性和若干索引屬性的任意對象

可迭代對象: 你可以從它身上迭代出若干個元素的對象,比如有 Map 和 Set 等(Map 與 Set 均為 ES6 中新的對象)

var arr = Array.from("Hello");
console.log(arr);

運行結(jié)果:

[ "H", "e", "l", "l", "o" ]
8、Array.values()

將一個數(shù)組轉(zhuǎn)換成一個可迭代的對象,該對象包含數(shù)組每個索引的值。

var arr = ["a", "b", "c"];
var obj = arr.values();
for (let letter of obj) {
    console.log(letter);
}

運行結(jié)果:

a
b
c

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/86057.html

相關(guān)文章

  • JS淬煉: Array進(jìn)階

    摘要:的這種實現(xiàn)方式導(dǎo)致了一些尷尬問題,比如刪除元素元素遍歷。后面的參數(shù)被忽略掉了,表示并沒有要插入的元素。其實,的本質(zhì)是跟蹤中的,并始終保持值是。這時候,雖然不大可能,可能會在中間某個中被用戶重新定義。但是在上進(jìn)行這種操作是很糟糕的。 在Javascript中,array是一個類數(shù)組的object。顧名思義,它能夠在一個變量上存儲多個值。 數(shù)組是值的有序集合。每個值叫做一個元素,而每個元素...

    jimhs 評論0 收藏0
  • JavaScript 在 V8 中的元素種類及性能優(yōu)化

    摘要:常規(guī)元素,不能表示為或雙精度的值。元素種類可從過渡轉(zhuǎn)變?yōu)椤_@是一個簡化的可視化,僅顯示最常見的元素種類只能通過格子向下過渡。目前有種不同的元素種類,每種元素都有自己的一組可能的優(yōu)化。再次重申更具體的元素種類可以進(jìn)行更細(xì)粒度的優(yōu)化。 原文:Elements kinds in V8 JavaScript 對象可以具有與它們相關(guān)聯(lián)的任意屬性。對象屬性的名稱可以包含任何字符。JavaScrip...

    UsherChen 評論0 收藏0
  • 學(xué)習(xí)筆記: JS數(shù)組

    摘要:數(shù)組元素甚至可以是對象或其它數(shù)組。它執(zhí)行的是淺拷貝,這意味著如果數(shù)組元素是對象,兩個數(shù)組都指向相同的對象,對新數(shù)組中的對象修改,會在舊的數(shù)組的相同對象中反應(yīng)出來。 JS中的數(shù)組是弱類型的,數(shù)組中可以含有不同類型的元素。數(shù)組元素甚至可以是對象或其它數(shù)組。JS引擎一般會優(yōu)化數(shù)組,按索引訪問數(shù)組常常比訪問一般對象屬性明顯迅速。數(shù)組長度范圍 from 0 to 4,294,967,295(2^...

    archieyang 評論0 收藏0
  • JavaScript面向?qū)ο缶幊獭?em>Array類型

    摘要:中并沒有明確的數(shù)組數(shù)據(jù)類型。返回數(shù)組對象的原始值。專門用于篩選出數(shù)組中符合函數(shù)判斷條件的元素組成的心數(shù)組。專門用于對原數(shù)組中每個元素執(zhí)行相同的函數(shù)對象規(guī)定的操作。 概述 一維數(shù)組 數(shù)組是一個有序的數(shù)據(jù)集合,可以通過數(shù)組名稱和索引進(jìn)行訪問。JavaScript中并沒有明確的數(shù)組數(shù)據(jù)類型。 二維數(shù)組 數(shù)組是可以嵌套的,這就意味著一個數(shù)組可以作為一個袁旭被包含在另一個數(shù)組里面。利用JavaS...

    DirtyMind 評論0 收藏0
  • array數(shù)組類型

    摘要:中并沒有明確的數(shù)組數(shù)據(jù)類型。創(chuàng)建一維數(shù)組具有以下幾種方式二維數(shù)組數(shù)組是可以嵌套,這就意味著一個數(shù)組可以作為一個數(shù)組被包含在另外一個數(shù)組里面。利用這個特點,創(chuàng)建二維數(shù)組,即數(shù)組的數(shù)組。刪除數(shù)組的最后一個元素并返回刪除的元素。 Array 概述 一維數(shù)組 數(shù)組是一個有序的數(shù)據(jù)集合,可以通過數(shù)組名稱和索引進(jìn)行訪問。JavaScript中并沒有明確的數(shù)組數(shù)據(jù)類型。創(chuàng)建一維數(shù)組具有以下幾種方式:...

    lemanli 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<