首先是Es5系列
1昂利、indexOf
用途: 用于查找數(shù)組中是否存在某個值题篷,如果存在則返回某個值的下標啊研,否則返回-1
let list = [1, 2, 3];
console.log(list.indexOf(2)) // 1
console.log(list.indexOf("蛙人")) // -1
2、map
用途: map是一個數(shù)組函數(shù)方法,接收三個參數(shù),value,index,self冻押,返回值是處理完的結果。
let 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)
3盛嘿、forEach
用途: 用于遍歷一個數(shù)組洛巢,接收三個參數(shù),value次兆,index稿茉,self,返回值為undefined
let 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
4芥炭、splice
用途: 用于數(shù)組刪除或替換內容漓库,接收三個參數(shù):
第一個參數(shù)是,刪除或添加的位置
第二個參數(shù)是园蝠,要刪除的幾位渺蒿,如果為0則不刪除
第三個參數(shù)是,向數(shù)組添加內容
let list = [1, 2, 3];
list.splice(0, 1) // 把第0個位置彪薛,給刪除一位
console.log(list) // [2, 3]
list.splice(0, 1, "蛙人") // 把第0個位置茂装,給刪除一位,添加上一個字符串
console.log(list) // ["蛙人", 2, 3]
list.splice(0, 2, "蛙人") // 把第0個位置陪汽,給刪除2位训唱,添加上一個字符串
console.log(list) // ["蛙人", 3]
5褥蚯、slice
用途: 用于截取數(shù)組值挚冤,接收兩個參數(shù),第一個參數(shù)是要獲取哪個值的下標赞庶,第二個參數(shù)是截取到哪個下標的前一位训挡。
let list = [1, 2, 3];
let res = list.slice(1, 3) // 從第一位下標開始截取,到第三位下標的前一位歧强,所以截取出來就是 [2, 3]
console.log(res) // [2, 3]
6澜薄、filter
用途: 用于過濾數(shù)組內的符合條件的值,返回值為滿足條件的數(shù)組對象
let list = [1, 2, 3];
let res = list.filter(item => item > 1);
console.log(res) // [2, 3]
7摊册、every
用途: 用于檢測數(shù)組所有元素是否都符合指定條件肤京,返回值為Boolean , 該方法是數(shù)組中必須全部值元素滿足條件返回true,否則false
let list = [1, 2, 3];
let res = list.every(item => item > 0)
console.log(res) // true
let res1 = list.every(item => item > 1)
console.log(res1) // false
8、some
用途: 用于檢測數(shù)組中的元素是否滿足指定條件忘分,返回值為Boolean , 該方法是只要數(shù)組中有一項滿足條件就返回true棋枕,否則false
let list = [1, 2, 3];
let res = list.some(item => item > 0)
console.log(res) // true
9、reduce
用途: 該方法接收一個函數(shù)作為累加器妒峦,數(shù)組中的每個值(從左到右)開始縮減重斑,最終計算為一個值。該方法回調函數(shù)接收四個參數(shù)
第一個參數(shù):初始值, 或者計算結束后的返回值
第二個參數(shù):當前元素
第二個參數(shù):當前元素的索引
第四個參數(shù):當前元素所屬的數(shù)組對象肯骇,本身
我們一般只用前兩個就行窥浪,reduce第一個參數(shù)回調函數(shù),第二個參數(shù)是初始值
let list = [1, 2, 3];
let res = list.reduce(( prev, cur ) => prev += cur, 0)
console.log(res) // 6
9笛丙、reverse
用途: 用于數(shù)組反轉
let list = [1, 2, 3];
let res = list.reverse();
console.log(res) // [3, 2, 1]
10漾脂、join
用途: 用于數(shù)據以什么形式拼接
let list = [1, 2, 3];
let res = list.join("-");
console.log(res) // 1-2-3
let sum = eval(list.join("+"))
console.log(sum) // 6
11、sort
用途: 用于將數(shù)組排序胚鸯,排序規(guī)則看返回值
返回值為正數(shù),后面的數(shù)在前面
返回值為負數(shù),前面的數(shù)不變,還在前面
返回值為0,都不動
let list = [1, 2, 3];
let sort = list.sort((a, b) => b - a)
console.log(sort) // [3, 2, 1]
12符相、concat
用途: 用于合并數(shù)組原始
let list = [1, 2, 3];
let res = list.concat([1, 2, 3])
console.log(res) // [1, 2, 3, 1, 2, 3]
13、push
用途: 向數(shù)組后面添加元素蠢琳,返回值為數(shù)組的length
let list = [1, 2, 3];
let res = list.push(1)
console.log(res) // 4
14啊终、pop
用途: 用于刪除數(shù)組尾部的元素,返回值為刪除的元素
let list = [1, 2, 3];
let res = list.pop()
console.log(res) // 3
15傲须、shift
用途: 用于刪除數(shù)組的頭部蓝牲,返回值為刪除的元素
let list = [1, 2, 3];
let res = list.shift()
console.log(res) // 1
16、unshift
用途: 向數(shù)組的頭部添加元素泰讽,返回值為數(shù)組的length
let list = [1, 2, 3];
let res = list.unshift(1)
console.log(res) // 4
17例衍、toString
用途: 用于將數(shù)組內容轉換為字符串
let list = [1, 2, 3];
let res = list.toString()
console.log(res) // 1,2,3
18、Array.isArray
用途: 檢測對象是不是一個數(shù)組
let list = [1, 2, 3];
let res =? Array.isArray(list)
console.log(res) // true
其次是Es5系列
1已卸、includes
用途: 檢測數(shù)組中是否存在該元素佛玄,返回Boolean值
let list = [1, 2, 3];
let res = list.includes("蛙人")
let res1 = list.includes(1)
console.log(res, res1) // false true
2、find
用途: 查找數(shù)組的元素累澡,滿足條件的返回單個值梦抢,按照就近原則返回
let list = [1, 2, 3];
let res = list.find((item) => item > 1)
console.log(res) // 2, 按照就近原則返回
3、findIndex
用途: 查找數(shù)組中元素愧哟,滿足條件的返回數(shù)組下標
let list = [1, 2, 3];
let res = list.findIndex((item) => item > 1)
console.log(res) // 1, 按照就近原則返回下標
4奥吩、flat
用途: 用于拉平嵌套數(shù)組對象
let list = [1, 2, 3, [4, [5]]];
let res = list.flat(Infinity)
console.log(res) // [1, 2, 3, 4, 5]
5、fill
用途: 用于填充數(shù)組對象
let list = [1, 2, 3];
let res = list.fill(1)
console.log(res) // [1, 1, 1]
6蕊梧、Array.from
用途: 將偽數(shù)組轉換為真數(shù)組
let res = Array.from(document.getElementsByTagName("div"))
console.log(res) // 轉換為真數(shù)組就可以調用數(shù)組原型的方法
7霞赫、Array.of
用途: 用于生成一個數(shù)組對象,主要是用來彌補Array()的不足
let res = Array.of(1, 2, 3)
console.log(res) // [1, 2, 3]
總結:
其實用的比較多的還是Es5的方法偏多肥矢,歡迎大家補充端衰。
其中總結咯一些會改變原始數(shù)組值的有
splice、reverse、sort旅东、push惕味、pop、shift玉锌、unshift名挥、fill