Es6 +
includes
檢測數(shù)組中是否存在該元素酗电,返回Boolean值
const list = [1, 2, 3];
const res = list.includes("0")
const res1 = list.includes(1)
console.log(res, res1) // false true
find
查找數(shù)組的元素绽诚,滿足條件的返回單個(gè)值典徊,按照就近原則返回
const list = [1, 2, 3];
const res = list.find((item) => item > 1)
console.log(res) // 2, 按照就近原則返回
findIndex
查找數(shù)組中元素,滿足條件的返回?cái)?shù)組下標(biāo)
const list = [1, 2, 3];
const res = list.findIndex((item) => item > 1)
console.log(res) // 1, 按照就近原則返回下標(biāo)
flat
用于填充數(shù)組對象
const list = [1, 2, 3];
const res = list.fill(1)
console.log(res) // [1, 1, 1]
Array.isArray
檢測對象是不是一個(gè)數(shù)組
const list = [1, 2, 3];
const res = Array.isArray(list)
console.log(res) // true
Array.from
將偽數(shù)組轉(zhuǎn)換為真數(shù)組
const res = Array.from(document.getElementsByTagName("div"))
console.log(res) // 轉(zhuǎn)換為真數(shù)組就可以調(diào)用數(shù)組原型的方法
Array.of
用于生成一個(gè)數(shù)組對象恩够,主要是用來彌補(bǔ)Array()的不足
const res = Array.of(1, 2, 3)
console.log(res) // [1, 2, 3]
Es5系列
indexOf
用于查找數(shù)組中是否存在某個(gè)值卒落,如果存在則返回某個(gè)值的下標(biāo),否則返回-1
const list = [1, 2, 3];
console.log(list.indexOf(2)) // 1
console.log(list.indexOf("0")) // -1
map
map是一個(gè)數(shù)組函數(shù)方法蜂桶,接收三個(gè)參數(shù)儡毕,value,index屎飘,self妥曲,返回值是處理完的結(jié)果贾费。
const list = [1, 2, 3];
const res = list.map((value, key, self) => {
console.log(value) // 1 2 3
console.log(key) // 0 1 2
console.log(self) // [1, 2, 3]
return value * 2
})
console.log(res)
forEach
用于遍歷一個(gè)數(shù)組钦购,接收三個(gè)參數(shù),value褂萧,index押桃,self,返回值為undefined
const list = [1, 2, 3];
const res = list.forEach((value, key, self) => {
console.log(value) // 1 2 3
console.log(key) // 0 1 2
console.log(self) // [1, 2, 3]
return 123
})
console.log(res) // undefined
splice
用于數(shù)組刪除或替換內(nèi)容导犹,接收三個(gè)參數(shù)
第一個(gè)參數(shù)是唱凯,刪除或添加的位置
第二個(gè)參數(shù)是,要?jiǎng)h除的幾位谎痢,如果為0則不刪除
第三個(gè)參數(shù)是磕昼,向數(shù)組添加內(nèi)容
const list = [1, 2, 3];
const.splice(0, 1) // 把第0個(gè)位置,給刪除一位
console.log(list) // [2, 3]
list.splice(0, 1, "4") // 把第0個(gè)位置节猿,給刪除一位票从,添加上一個(gè)字符串
console.log(list) // ["4", 2, 3]
list.splice(0, 2, "4") // 把第0個(gè)位置漫雕,給刪除2位,添加上一個(gè)字符串
console.log(list) // ["4", 3]
slice
用于截取數(shù)組值峰鄙,接收兩個(gè)參數(shù)浸间,第一個(gè)參數(shù)是要獲取哪個(gè)值的下標(biāo),第二個(gè)參數(shù)是截取到哪個(gè)下標(biāo)的前一位
const list = [1, 2, 3];
const res = list.slice(1, 3) // 從第一位下標(biāo)開始截取吟榴,到第三位下標(biāo)的前一位魁蒜,所以截取出來就是 [2, 3]
console.log(res) // [2, 3]
filter
用于過濾數(shù)組內(nèi)的符合條件的值,返回值為滿足條件的數(shù)組對象
const list = [1, 2, 3];
const res = list.filter(item => item > 1);
console.log(res) // [2, 3]
every
用于檢測數(shù)組所有元素是否都符合指定條件吩翻,返回值為Boolean , 該方法是數(shù)組中必須全部值元素滿足條件返回true兜看,否則false
const list = [1, 2, 3];
const res = list.every(item => item > 0)
console.log(res) // true
const res1 = list.every(item => item > 1)
console.log(res1) // false
some
用于檢測數(shù)組中的元素是否滿足指定條件,返回值為Boolean , 該方法是只要數(shù)組中有一項(xiàng)滿足條件就返回true狭瞎,否則false
const list = [1, 2, 3];
const res = list.some(item => item > 0)
console.log(res) // true
reduce
該方法接收一個(gè)函數(shù)作為累加器铣减,數(shù)組中的每個(gè)值(從左到右)開始縮減,最終計(jì)算為一個(gè)值脚作。該方法回調(diào)函數(shù)接收四個(gè)參數(shù)
第一個(gè)參數(shù):初始值, 或者計(jì)算結(jié)束后的返回值
第二個(gè)參數(shù):當(dāng)前元素
第二個(gè)參數(shù):當(dāng)前元素的索引
第四個(gè)參數(shù):當(dāng)前元素所屬的數(shù)組對象葫哗,本身
我們一般只用前兩個(gè)就行,reduce第一個(gè)參數(shù)回調(diào)函數(shù)球涛,第二個(gè)參數(shù)是初始值
const list = [1, 2, 3];
const res = list.reduce(( prev, cur ) => prev += cur, 0)
console.log(res) // 6
reverse
用于數(shù)組反轉(zhuǎn)
const list = [1, 2, 3];
const res = list.reverse();
console.log(res) // [3, 2, 1]
join
用于數(shù)據(jù)以什么形式拼接
const list = [1, 2, 3];
const res = list.join("-");
console.log(res) // 1-2-3
const sum = eval(list.join("+"))
console.log(sum) // 6
sort
用于將數(shù)組排序劣针,排序規(guī)則看返回值
返回值為正數(shù),后面的數(shù)在前面
返回值為負(fù)數(shù),前面的數(shù)不變,還在前面
返回值為0,都不動(dòng)
const list = [1, 2, 3];
const sort = list.sort((a, b) => b - a)
console.log(sort) // [3, 2, 1]
concat
用于合并數(shù)組原始
const list = [1, 2, 3];
const res = list.concat([4, 5, 6])
console.log(res) // [1, 2, 3, 4, 5, 6]
//es6
const list = [1, 2, 3];
const list1 = [4, 5, 6];
console.log(...list, ...list1) // [1, 2, 3, 4, 5, 6]
push
向數(shù)組后面添加元素,返回值為數(shù)組的length
const list = [1, 2, 3];
const res = list.push(1)
console.log(res) // 4
pop
用于刪除數(shù)組尾部的元素亿扁,返回值為刪除的元素
const list = [1, 2, 3];
const res = list.pop()
console.log(res) // 3
shift
刪除數(shù)組的頭部捺典,返回值為刪除的元素
const list = [1, 2, 3];
const res = list.shift()
console.log(res) // 1
unshift
向數(shù)組的頭部添加元素,返回值為數(shù)組的length
const list = [1, 2, 3];
const res = list.unshift(1)
console.log(res) // 4
toString
用于將數(shù)組內(nèi)容轉(zhuǎn)換為字符串
const list = [1, 2, 3];
const res = list.toString()
console.log(res) // 1,2,3