溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

ES5和Es6數(shù)組方法的區(qū)別

發(fā)布時(shí)間:2021-09-17 15:10:43 來源:億速云 閱讀:150 作者:柒染 欄目:web開發(fā)

本篇文章給大家分享的是有關(guān)ES5和Es6數(shù)組方法的區(qū)別,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

ES5和Es6數(shù)組方法的區(qū)別

初衷: 在面試中,面試官經(jīng)常問到說一下Es5和Es6的數(shù)組方法有哪些,有很多同學(xué)老是分不清楚,今天就來分享一下。

Es5系列

indexOf

用途: 用于查找數(shù)組中是否存在某個(gè)值,如果存在則返回某個(gè)值的下標(biāo),否則返回-1

let list = [1, 2, 3];  console.log(list.indexOf(2)) // 1 console.log(list.indexOf("蛙人")) // -1

map

用途: map是一個(gè)數(shù)組函數(shù)方法,接收三個(gè)參數(shù),value,index,self,返回值是處理完的結(jié)果。

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

用途: 用于遍歷一個(gè)數(shù)組,接收三個(gè)參數(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

splice

用途: 用于數(shù)組刪除或替換內(nèi)容,接收三個(gè)參數(shù):

  • 第一個(gè)參數(shù)是,刪除或添加的位置

  • 第二個(gè)參數(shù)是,要?jiǎng)h除的幾位,如果為0則不刪除

  • 第三個(gè)參數(shù)是,向數(shù)組添加內(nèi)容

let list = [1, 2, 3];  list.splice(0, 1) // 把第0個(gè)位置,給刪除一位 console.log(list) // [2, 3]  list.splice(0, 1, "蛙人") // 把第0個(gè)位置,給刪除一位,添加上一個(gè)字符串 console.log(list) // ["蛙人", 2, 3]  list.splice(0, 2, "蛙人") // 把第0個(gè)位置,給刪除2位,添加上一個(gè)字符串 console.log(list) // ["蛙人", 3]

 slice

用途: 用于截取數(shù)組值,接收兩個(gè)參數(shù),第一個(gè)參數(shù)是要獲取哪個(gè)值的下標(biāo),第二個(gè)參數(shù)是截取到哪個(gè)下標(biāo)的前一位。

let list = [1, 2, 3];  let res = list.slice(1, 3) // 從第一位下標(biāo)開始截取,到第三位下標(biāo)的前一位,所以截取出來就是 [2, 3] console.log(res) // [2, 3]

filter

用途: 用于過濾數(shù)組內(nèi)的符合條件的值,返回值為滿足條件的數(shù)組對(duì)象

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

every

用途:用于檢測(cè)數(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

some

用途: 用于檢測(cè)數(shù)組中的元素是否滿足指定條件,返回值為Boolean , 該方法是只要數(shù)組中有一項(xiàng)滿足條件就返回true,否則false

let list = [1, 2, 3];  let 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ù)組對(duì)象,本身

我們一般只用前兩個(gè)就行,reduce第一個(gè)參數(shù)回調(diào)函數(shù),第二個(gè)參數(shù)是初始值

let list = [1, 2, 3];  let res = list.reduce(( prev, cur ) => prev += cur, 0) console.log(res) // 6

reverse

用途: 用于數(shù)組反轉(zhuǎn)

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

join

用途: 用于數(shù)據(jù)以什么形式拼接

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

用途: 用于將數(shù)組排序,排序規(guī)則看返回值

  • 返回值為正數(shù),后面的數(shù)在前面

  • 返回值為負(fù)數(shù),前面的數(shù)不變,還在前面

  • 返回值為0,都不動(dòng)

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

concat

用途: 用于合并數(shù)組原始

let list = [1, 2, 3];  let res = list.concat([1, 2, 3]) console.log(res) // [1, 2, 3, 1, 2, 3]

push

用途: 向數(shù)組后面添加元素,返回值為數(shù)組的length

let list = [1, 2, 3];  let res = list.push(1) console.log(res) // 4

pop

用途: 用于刪除數(shù)組尾部的元素,返回值為刪除的元素

let list = [1, 2, 3];  let res = list.pop() console.log(res) // 3

shift

用途: 用于刪除數(shù)組的頭部,返回值為刪除的元素

let list = [1, 2, 3];  let res = list.shift() console.log(res) // 1

unshift

用途: 向數(shù)組的頭部添加元素,返回值為數(shù)組的length

let list = [1, 2, 3];  let res = list.unshift(1) console.log(res) // 4

toString

用途: 用于將數(shù)組內(nèi)容轉(zhuǎn)換為字符串

let list = [1, 2, 3];  let res = list.toString() console.log(res) // 1,2,3

Es6 +

includes

用途: 檢測(cè)數(shù)組中是否存在該元素,返回Boolean值

let list = [1, 2, 3];  let res = list.includes("蛙人") let res1 = list.includes(1) console.log(res, res1) // false true

find

用途: 查找數(shù)組的元素,滿足條件的返回單個(gè)值,按照就近原則返回

let list = [1, 2, 3];  let res = list.find((item) => item > 1) console.log(res) // 2, 按照就近原則返回

findIndex

用途: 查找數(shù)組中元素,滿足條件的返回?cái)?shù)組下標(biāo)

let list = [1, 2, 3];  let res = list.findIndex((item) => item > 1) console.log(res) // 1, 按照就近原則返回下標(biāo)

flat

用途: 用于拉平嵌套數(shù)組對(duì)象

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

fill

用途: 用于填充數(shù)組對(duì)象

let list = [1, 2, 3];  let res = list.fill(1) console.log(res) // [1, 1, 1]

Array.isArray

用途: 檢測(cè)對(duì)象是不是一個(gè)數(shù)組

let list = [1, 2, 3];  let res =  Array.isArray(list) console.log(res) // true

Array.from

用途: 將偽數(shù)組轉(zhuǎn)換為真數(shù)組

let res = Array.from(document.getElementsByTagName("div")) console.log(res) // 轉(zhuǎn)換為真數(shù)組就可以調(diào)用數(shù)組原型的方法

Array.of

用途: 用于生成一個(gè)數(shù)組對(duì)象,主要是用來彌補(bǔ)Array()的不足

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

改變?cè)紨?shù)組值的有哪些

splice、reverse、sort、push、pop、shift、unshift、fill

以上就是ES5和Es6數(shù)組方法的區(qū)別,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI