還在傻傻分不清ES五、Es6數組方法?各大姿式來襲

前言

初衷: 在面試中,面試官常常問到說一下Es5和Es6的數組方法有哪些,有不少同窗總是分不清楚,今天筆者就來分享一下。javascript

適合人羣: 前端初級開發前端

Es5系列

indexOf

用途: 用於查找數組中是否存在某個值,若是存在則返回某個值的下標,不然返回-1java

let list = [1, 2, 3];

console.log(list.indexOf(2)) // 1
console.log(list.indexOf("蛙人")) // -1
複製代碼

map

用途: map是一個數組函數方法,接收三個參數,valueindexself,返回值是處理完的結果。git

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)
複製代碼

forEach

用途: 用於遍歷一個數組,接收三個參數,valueindexself,返回值爲undefinedgithub

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
複製代碼

splice

用途: 用於數組刪除或替換內容,接收三個參數:面試

  • 第一個參數是,刪除或添加的位置
  • 第二個參數是,要刪除的幾位,若是爲0則不刪除
  • 第三個參數是,向數組添加內容
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]
複製代碼

slice

用途: 用於截取數組值,接收兩個參數,第一個參數是要獲取哪一個值的下標,第二個參數是截取到哪一個下標的前一位。npm

let list = [1, 2, 3];

let res = list.slice(1, 3) // 從第一位下標開始截取,到第三位下標的前一位,因此截取出來就是 [2, 3]
console.log(res) // [2, 3]
複製代碼

filter

用途: 用於過濾數組內的符合條件的值,返回值爲知足條件的數組對象數組

let list = [1, 2, 3];

let res = list.filter(item => item > 1);
console.log(res) // [2, 3]
複製代碼

every

用途: 用於檢測數組全部元素是否都符合指定條件,返回值爲Boolean , 該方法是數組中必須所有值元素知足條件返回true,不然falsemarkdown

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
複製代碼

some

用途: 用於檢測數組中的元素是否知足指定條件,返回值爲Boolean , 該方法是隻要數組中有一項知足條件就返回true,不然false數據結構

let list = [1, 2, 3];

let res = list.some(item => item > 0)
console.log(res) // true
複製代碼

reduce

用途: 該方法接收一個函數做爲累加器,數組中的每一個值(從左到右)開始縮減,最終計算爲一個值。該方法回調函數接收四個參數

  • 第一個參數:初始值, 或者計算結束後的返回值
  • 第二個參數:當前元素
  • 第二個參數:當前元素的索引
  • 第四個參數:當前元素所屬的數組對象,自己

咱們通常只用前兩個就行,reduce第一個參數回調函數,第二個參數是初始值

let list = [1, 2, 3];

let res = list.reduce(( prev, cur ) => prev += cur, 0)
console.log(res) // 6
複製代碼

reverse

用途: 用於數組反轉

let list = [1, 2, 3];

let res = list.reverse();
console.log(res) // [3, 2, 1]
複製代碼

join

用途: 用於數據以什麼形式拼接

let list = [1, 2, 3];

let res = list.join("-");
console.log(res) // 1-2-3

let sum = eval(list.join("+"))
console.log(sum) // 6
複製代碼

sort

用途: 用於將數組排序,排序規則看返回值

  • 返回值爲正數,後面的數在前面
  • 返回值爲負數,前面的數不變,還在前面
  • 返回值爲0,都不動
let list = [1, 2, 3];

let sort = list.sort((a, b) => b - a)
console.log(sort) // [3, 2, 1]
複製代碼

concat

用途: 用於合併數組原始

let list = [1, 2, 3];

let res = list.concat([1, 2, 3])
console.log(res) // [1, 2, 3, 1, 2, 3]
複製代碼

push

用途: 向數組後面添加元素,返回值爲數組的length

let list = [1, 2, 3];

let res = list.push(1)
console.log(res) // 4
複製代碼

pop

用途: 用於刪除數組尾部的元素,返回值爲刪除的元素

let list = [1, 2, 3];

let res = list.pop()
console.log(res) // 3
複製代碼

shift

用途: 用於刪除數組的頭部,返回值爲刪除的元素

let list = [1, 2, 3];

let res = list.shift()
console.log(res) // 1
複製代碼

unshift

用途: 向數組的頭部添加元素,返回值爲數組的length

let list = [1, 2, 3];

let res = list.unshift(1)
console.log(res) // 4
複製代碼

toString

用途: 用於將數組內容轉換爲字符串

let list = [1, 2, 3];

let res = list.toString()
console.log(res) // 1,2,3
複製代碼

Array.isArray

用途: 檢測對象是否是一個數組

let list = [1, 2, 3];

let res =  Array.isArray(list)
console.log(res) // true
複製代碼

Es6+ 系列

includes

用途: 檢測數組中是否存在該元素,返回Boolean

let list = [1, 2, 3];

let res = list.includes("蛙人")
let res1 = list.includes(1)
console.log(res, res1) // false true
複製代碼

find

用途: 查找數組的元素,知足條件的返回單個值,按照就近原則返回

let list = [1, 2, 3];

let res = list.find((item) => item > 1)
console.log(res) // 2, 按照就近原則返回
複製代碼

findIndex

用途: 查找數組中元素,知足條件的返回數組下標

let list = [1, 2, 3];

let res = list.findIndex((item) => item > 1)
console.log(res) // 1, 按照就近原則返回下標
複製代碼

flat

用途: 用於拉平嵌套數組對象

let list = [1, 2, 3, [4, [5]]];

let res = list.flat(Infinity)
console.log(res) // [1, 2, 3, 4, 5]
複製代碼

fill

用途: 用於填充數組對象

let list = [1, 2, 3];

let res = list.fill(1)
console.log(res) // [1, 1, 1]
複製代碼

Array.from

用途: 將僞數組轉換爲真數組

let res = Array.from(document.getElementsByTagName("div"))
console.log(res) // 轉換爲真數組就能夠調用數組原型的方法
複製代碼

Array.of

用途: 用於生成一個數組對象,主要是用來彌補Array()的不足

let res = Array.of(1, 2, 3)
console.log(res) // [1, 2, 3]
複製代碼

改變原始數組值的有哪些

splicereversesortpushpopshiftunshiftfill

結語

這裏keysvaluesentries就不寫啦,它們使用數組方式的話,返回的是Iterator遍歷器對象。歡迎你們查漏補缺經常使用數組方法哦

感謝

謝謝你讀完本篇文章,但願對你能有所幫助,若有問題歡迎各位指正。

我是蛙人(✿◡‿◡),若是以爲寫得能夠的話,請點個贊吧❤。

感興趣的小夥伴能夠加入 [ 前端娛樂圈交流羣 ] 歡迎你們一塊兒來交流討論

寫做不易,「點贊」+「在看」+「轉發」 謝謝支持❤

往期好文

《分享15個Webpack實用的插件!!!》

《手把手教你寫一個Vue組件發佈到npm且可外鏈引入使用》

《分享12個Webpack中經常使用的Loader》

《聊聊什麼是CommonJs和Es Module及它們的區別》

《帶你輕鬆理解數據結構之Map》

《這些工做中用到的JavaScript小技巧你都知道嗎?》

《【建議收藏】分享一些工做中經常使用的Git命令及特殊問題場景怎麼解決》

《你真的瞭解ES6中的函數特性麼?》

相關文章
相關標籤/搜索