concat() 用於連接兩個或多個數組。該方法不會改變現有的數組,而僅僅會返回被連接數組的一個副本。 every() 用於檢測數組所有元素是否都符合指定條件(通過函數提供)。 every() 方法使用指定函數檢測數組中的所有元素: 如果數組中檢測到有一個元素不滿足,則整個表達式返回 false , ...
concat()
用於連接兩個或多個數組。該方法不會改變現有的數組,而僅僅會返回被連接數組的一個副本。
var a = ["aa","ccc"]; var b = ["vv","mm"]; var c = ["123"]; var d = a.contac(b,c); ==> ["aa","ccc","vv","mm","123"]
every()
用於檢測數組所有元素是否都符合指定條件(通過函數提供)。
every() 方法使用指定函數檢測數組中的所有元素:
- 如果數組中檢測到有一個元素不滿足,則整個表達式返回 false ,且剩餘的元素不會再進行檢測。
- 如果所有元素都滿足條件,則返回 true。
註意: every() 不會對空數組進行檢測。
註意: every() 不會改變原始數組。
var ary = [3,4,5,6,7] var result = ary.every(function(item){ return item>5; }) ==> false
filter()
創建一個新的數組,新數組中的元素是通過檢查指定數組中符合條件的所有元素。
註意: filter() 不會對空數組進行檢測。
註意: filter() 不會改變原始數組。
var ary = [2,3,5,6,7]; var result = ary.filter(function(item){ return item>3; }); ==> [5,6,7]
forEach()
用於調用數組的每個元素,並將元素傳遞給回調函數。
var ary = [3,4,5,6,7] var result = ary.forEach(function(item,index){ console.log(item,index) });
includes()
用來判斷一個數組是否包含一個指定的值,如果是返回 true,否則false。
arr.includes(searchElement) arr.includes(searchElement, fromIndex) // searchElement 要查找的元素 // fromIndex 從該索引處開始查找 searchElement。如果fromIndex 大於等於數組長度 ,則返回 false ,該數組不會被搜索
如果為負值,則按升序從 array.length + fromIndex 的索引開始搜索。預設為 0。如果計算出的索引小於 0,則整個數組都會被搜索。
var arr = ['a', 'b', 'c']; arr.includes('a'); // true arr.includes('a', -100); // true
indexOf()
可返回數組中某個指定的元素位置。如果在數組中沒找到指定元素則返回 -1。
var num = [1,2,3,4,'Apple']; var a = num.indexOf("Apple"); //4
lastIndexOf()
可返回一個指定的元素在數組中最後出現的位置,在一個數組中的指定位置從後向前搜索。如果要檢索的元素沒有出現,則該方法返回 -1。
var num = [1,2,3,4,'Apple']; var a = num.lastIndexOf("Apple"); //4
isArray()
用於判斷一個對象是否為數組。如果對象是數組返回 true,否則返回 false。
var item = []; Array.isArray(item); //true
join()
用於把數組中的所有元素轉換一個字元串。元素是通過指定的分隔符進行分隔的。
var fruits = ["Banana", "Orange", "Apple", "Mango"]; var energy = fruits.join(); //Banana,Orange,Apple,Mango var energy = fruits.join("|"); //Banana|Orange|Apple|Mango
map()
返回一個新數組,數組中的元素為原始數組元素調用函數處理後的值。
map() 方法按照原始數組元素順序依次處理元素。
註意: map() 不會對空數組進行檢測。
註意: map() 不會改變原始數組。
var ary= [4,9,16,25]; var result = ary.map(Math.sqrt); //求平方根:result ==> 2,3,4,5
pop()
用於刪除數組的最後一個元素並返回刪除的元素。註意:此方法改變原數組長度。
var ary = [2,4,5,6]; var del = ary.pop(); //del ==> 6 // ary ==> 2,4,5
push()
可向數組的末尾添加一個或多個元素,並返回新的長度。註意:此方法改變原數組長度。
var ary = ['aa','bb','cc']; var result = ary.push('ss'); //result ==> 4 //ary ==> ['aa','bb','cc','ss']
shift()
用於刪除並返回數組的第一個元素。註意:此方法改變原數組長度。
var ary = [2,4,5,6]; var del = ary.shift(); //del ==> 2 // ary ==> 4,5,6
unshift()
可向數組的開頭添加一個或更多元素,並返回新的長度。註意:此方法改變原數組長度。
var ary = ['aa','bb','cc']; var result = ary.unshift('ss'); //result ==> 4 //ary ==> ['ss','aa','bb','cc']
reduce()
接收一個函數作為累加器,數組中的每個值(從左到右)開始縮減,最終計算為一個值。
這個函數必須接收兩個參數,reduce()
把結果繼續和序列的下一個元素做累積計算。
註意: reduce() 對於空數組是不會執行回調函數的。
var arr = [1, 3, 5, 7, 9]; arr.reduce(function (x, y) { return x + y; }); // 25
reduceRight() 方法的功能和 reduce() 功能是一樣的,不同的是 reduceRight() 從數組的末尾向前將數組中的數組項做累加。
reverse()
用於顛倒數組中元素的順序。
var fruits = [1, 2, 3, 4]; fruits.reverse(); // [4,3,2,1]
slice()
可從已有的數組中返回選定的元素。
slice()方法可提取字元串的某個部分,並以新的字元串返回被提取的部分。
註意: slice() 方法不會改變原始數組。
返回一個新的數組,包含從 start 到 end (不包括該元素)的 arrayObject 中的元素。
array.slice(start, end) //start 可選。規定從何處開始選取。如果是負數,那麼它規定從數組尾部開始算起的位置。 //end 可選。規定從何處結束選取。 //該參數是數組片斷結束處的數組下標。如果沒有指定該參數,那麼切分的數組包含從 start 到數組結束的所有元素。 //如果這個參數是負數,那麼它規定的是從數組尾部開始算起的元素。
var fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"]; var citrus = fruits.slice(1,3); // ["Orange", "Lemon"]
some()
用於檢測數組中的元素是否滿足指定條件(函數提供)。
some() 方法會依次執行數組的每個元素:
- 如果有一個元素滿足條件,則表達式返回true , 剩餘的元素不會再執行檢測。
- 如果沒有滿足條件的元素,則返回false。
var arr = [1, 3, 5, 7, 9]; arr.some(function (item) { return item>4; }); // true
sort()
用於對數組的元素進行排序。返回新的數組
排序順序可以是字母或數字,並按升序或降序。預設排序順序為按字母升序。
註意:當數字是按字母順序排列時"40"將排在"5"前面。
使用數字排序,你必須通過一個函數作為參數來調用。
函數指定數字是按照升序還是降序排列。
註意: 這種方法會改變原始數組!
var fruits = ["Banana", "Orange", "Apple", "Mango"]; fruits.sort(); // Apple,Banana,Mango,Orange //升序 var points = [40,100,1,5,25,10]; points.sort(function(a,b){return a-b}); //1,5,10,25,40,100 //降序 var points = [40,100,1,5,25,10]; points.sort(function(a,b){return b-a}); // 100,40,25,10,5,1
splice()
用於插入、刪除或替換數組的元素。
註意:這種方法會改變原始數組!
array.splice(index,howmany,item1,.....,itemX) //index 必需。規定從何處添加/刪除元素。該參數是開始插入和(或)刪除的數組元素的下標,必須是數字。 //howmany 必需。規定應該刪除多少元素。必須是數字,但可以是 "0"。如果未規定此參數,則刪除從 index 開始到原數組結尾的所有元素。 //item1, ..., itemX 可選。要添加到數組的新元素 //如果從 arrayObject 中刪除了元素,則返回的是含有被刪除的元素的數組。
//移除數組的第三個元素,併在數組第三個位置添加新元素: var fruits = ["Banana", "Orange", "Apple", "Mango"]; fruits.splice(2,1,"Lemon","Kiwi"); //["Banana", "Orange", "Lemon","Kiwi","Mango"] //從第三個位置開始刪除數組後的兩個元素: var fruits = ["Banana", "Orange", "Apple", "Mango"]; fruits.splice(2,2); //["Banana", "Orange"]
toString()
可把數組轉換為字元串,並返回結果。
註意: 數組中的元素之間用逗號分隔。
array.toString()
valueOf()
返回 Array 對象的原始值。
該原始值由 Array 對象派生的所有對象繼承。
valueOf() 方法通常由 JavaScript 在後臺自動調用,並不顯式地出現在代碼中。
註意: valueOf() 方法不會改變原數組。
//valueOf() 是數組對象的預設方法。 // fruits.valueOf()與 fruits返回值一樣。 var fruits = ["Banana", "Orange", "Apple", "Mango"]; var v=fruits.valueOf();