亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript數(shù)組 幾個(gè)常用方法總結(jié)

 更新時(shí)間:2021年11月10日 09:16:24   作者:四冥  
這篇文章主要介紹了JavaScript數(shù)組 幾個(gè)常用方法,主要概述的方法有filter()、map()、sort()、reduce()、forEach(),這些方法都是JavaScript常用到的方法,下面文章內(nèi)容詳細(xì)介紹了他們的語(yǔ)法、參數(shù)、返回值等資料,需要的朋友可以參考一下

1、前言

數(shù)組方法有太多了,本文記錄一些本人容易記錯(cuò)的一些數(shù)組方法,用于鞏固及復(fù)習(xí)。
后續(xù)會(huì)慢慢的將其他數(shù)組方法添加進(jìn)來(lái)。
善用數(shù)組方法可以使數(shù)據(jù)處理變的優(yōu)雅且簡(jiǎn)單。

那下面讓我們開始吧:

2、filter()

描述:

filter() 方法創(chuàng)建一個(gè)新數(shù)組,并將符合條件的所有元素添加到創(chuàng)建的新數(shù)組中。

語(yǔ)法:

Array.filter(callback(element, index, array) { // 函數(shù)體 }, thisValue)


參數(shù):

callbackthisValue:

參數(shù) 是否可選 描述
參數(shù)一 callback 必選 用來(lái)測(cè)試數(shù)組的每個(gè)元素的函數(shù)。返回 true 表示該元素通過(guò)測(cè)試,保留該元素,false 則不保留。它接收三個(gè)參數(shù)。
參數(shù)二 thisValue 可選 執(zhí)行 callback 時(shí),用于 this 的值。
對(duì)象作為該執(zhí)行回調(diào)時(shí)使用,傳遞給函數(shù)。
如果省略了 thisValue ,"this" 的值為 "undefined"

callback的參數(shù)列表:

參數(shù) 是否可選 描述
參數(shù)一 element 必選 當(dāng)前元素
參數(shù)二 index 可選 當(dāng)前元素的索引值
參數(shù)三 array 可選 調(diào)用了 filter 的數(shù)組本身

thisValue的參數(shù):

執(zhí)行 callback 時(shí),用于 this 的值。

返回值:

是一個(gè)由 filter() 參數(shù)一函數(shù)的返回值組成的新數(shù)組

示例:

let users = [
  {id: 11, name: "孫悟空"},
  {id: 21, name: "豬八戒"},
  {id: 31, name: "沙和尚"}
];

// 返回前兩個(gè)用戶的數(shù)組
let filterUsers = users.filter(item => item.id < 31);

console.log(filterUsers.length); // 2

3、map()

描述:

map() 方法創(chuàng)建一個(gè)新數(shù)組,新數(shù)組的每個(gè)元素是調(diào)用一次給定函數(shù)的返回值。

語(yǔ)法:

Array.map(callback(currentValue, index, array) { // 函數(shù)體 }, thisValue)


參數(shù):

callbackthisValue

參數(shù) 是否可選 描述
參數(shù)一 callback 必選 數(shù)組中的每個(gè)元素都要運(yùn)行的回調(diào)函數(shù)。它接收三個(gè)參數(shù)。
參數(shù)二 thisValue 可選 執(zhí)行 callback 時(shí),用于 this 的值。
對(duì)象作為該執(zhí)行回調(diào)時(shí)使用,傳遞給函數(shù)。
如果省略了 thisValue ,"this" 的值為 "undefined"

callback的參數(shù)列表:

參數(shù) 是否可選 描述
參數(shù)一 element 必選 當(dāng)前元素
參數(shù)二 index 可選 當(dāng)前元素的索引值
參數(shù)三 array 可選 調(diào)用了 filter 的數(shù)組本身

thisValue的參數(shù):

執(zhí)行 callback 時(shí),用于 this 的值。

返回值:

是一個(gè)由原數(shù)組每個(gè)元素執(zhí)行回調(diào)函數(shù)的結(jié)果組成的新數(shù)組。

示例:

let number = [1, 2, 3].map(item => item + 1);

console.log(lengths); // 2, 3, 4

4、sort()

描述:

map() 方法在原數(shù)組上進(jìn)行修改更改元素的順序

注:默認(rèn)排序順序是在將元素轉(zhuǎn)換為字符串,然后比較它們的UTF-16代碼單元值序列時(shí)

語(yǔ)法:

Array.sort( compareFunction )


參數(shù):

compareFunction

參數(shù) 是否可選 描述
參數(shù)一 compareFunction 可選 規(guī)定排列順序的函數(shù)。如果省略,元素按照轉(zhuǎn)換為的字符串的各個(gè)字符的Unicode位點(diǎn)進(jìn)行排序。

compareFunction的參數(shù)列表:

參數(shù) 是否可選 描述
參數(shù)一 firstEl 必選 第一個(gè)用于比較的元素。
參數(shù)二 secondEl 必選 第二個(gè)用于比較的元素。

compareFunction返回值

返回一個(gè)說(shuō)明這兩個(gè)值順序的數(shù)字

  • 若 a 小于 b,在排序后的數(shù)組中 a 應(yīng)該出現(xiàn)在 b 之前,則返回一個(gè)小于 0 的值。
  • 若 a 等于 b,則返回 0。
  • 若 a 大于 b,則返回一個(gè)大于 0 的值。

返回值:

返回值為排序后的數(shù)組,但是返回值通常會(huì)被忽略,因?yàn)樾薷牧嗽瓟?shù)組。

示例:

let number = [1, 2, 3].map(item => item + 1);

console.log(lengths); // 2, 3, 4

5、reduce()

描述:
reduce() 方法為數(shù)組中的每一個(gè)元素依次執(zhí)行(升序執(zhí)行)回調(diào)函數(shù),不包括數(shù)組中被刪除或從未被賦值的元素。將其結(jié)果計(jì)算為一個(gè)值。

注:reduce() 可以作為一個(gè)高階函數(shù),用于函數(shù)的 compose。

語(yǔ)法:

Array.reduce(callback(accumulator, currentValue, index, array), initialValue)


參數(shù):

callbackinitialValue

參數(shù) 是否可選 描述
參數(shù)一 callback 必選 執(zhí)行數(shù)組中每個(gè)數(shù)組元素的函數(shù) (如果沒有initialValue初始值那么第一個(gè)值不會(huì)執(zhí)行改函數(shù))它接收四個(gè)參數(shù)。
參數(shù)二 initialValue 可選 callback函數(shù)的初始值

callback的參數(shù)列表:

參數(shù) 是否可選 描述
參數(shù)一 accumulator 必選 累計(jì)器累計(jì)回調(diào)的返回值; 它是上一次調(diào)用回調(diào)時(shí)返回的累積值,或initialValue。
參數(shù)二 currentValue 必選 當(dāng)前元素
參數(shù)三 index 可選 當(dāng)前元素的索引值
參數(shù)四 array 可選 調(diào)用了 reduce() 的數(shù)組本身

initialValue的參數(shù):

作為第一次調(diào)用 callback函數(shù)時(shí)的第一個(gè)參數(shù)的值。 如果沒有提供初始值,則將使用數(shù)組中的第一個(gè)元素作為初始值。 在沒有初始值的空數(shù)組上調(diào)用 reduce 將報(bào)錯(cuò)。

返回值:

函數(shù)累計(jì)處理后的結(jié)果
執(zhí)行完所有callback函數(shù)的accumulator參數(shù)

注:    我們的 reducer 函數(shù)的返回值分配給累計(jì)器,該返回值在數(shù)組的每個(gè)迭代中被記住,并最后成為最終的單個(gè)結(jié)果值。

示例:

let number = [1, 2, 3, 4];

let result = number.reduce((sum, current) => sum + current, 0);

console.log(result); // 10

6、forEach()

描述:

reduce() 方法為數(shù)組中的每一個(gè)元素依次執(zhí)行(升序執(zhí)行)回調(diào)函數(shù),不包括數(shù)組中被刪除或從未被賦值的元素。將其結(jié)果計(jì)算為一個(gè)值。

注:reduce() 可以作為一個(gè)高階函數(shù),用于函數(shù)的 compose。

語(yǔ)法:

Array.forEach(callback(currentValue , index , array), thisValue)

參數(shù):

callbackthisValue

參數(shù) 是否可選 描述
參數(shù)一 callback 必選 執(zhí)行數(shù)組中每個(gè)數(shù)組元素的函數(shù),它接收三個(gè)參數(shù)。
參數(shù)二 thisValue 可選 執(zhí)行 callback 時(shí),用于 this 的值。
對(duì)象作為該執(zhí)行回調(diào)時(shí)使用,傳遞給函數(shù)。
如果省略了 thisValue ,"this" 的值為 "undefined"

callback的參數(shù)列表:

參數(shù) 是否可選 描述
參數(shù)一 currentValue 必選 當(dāng)前元素
參數(shù)二 index 可選 當(dāng)前元素的索引值
參數(shù)三 array 可選 調(diào)用了 forEach() 的數(shù)組本身

thisValue的參數(shù):

執(zhí)行 callback 時(shí),用于 this 的值。

返回值:

該方法沒有返回值。

示例:

let number = [1, 2, 3, 4];

number.forEach((item, index ,array) =>{
 console.log(item); // 1/2/3/4
});

7、方法列表

方法屬性:

方法 改變?cè)瓟?shù)組 返回值描述 描述
filter() 過(guò)濾后的新數(shù)組 過(guò)濾器
map() 循環(huán)后的新數(shù)組 循環(huán)
sort() 為排序后的數(shù)組 排序
reduce() 為函數(shù)累計(jì)處理后的結(jié)果 累加器
forEach() 沒有返回值為undefined 循環(huán)

到此這篇關(guān)于JavaScript數(shù)組 幾個(gè)常用方法總結(jié)的文章就介紹到這了,更多相關(guān)JavaScript數(shù)組 幾個(gè)常用方法 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

8、本文參考

MDN中文官網(wǎng)https://developer.mozilla.org/zh-CN/
W3School 簡(jiǎn)體中文版https://www.w3school.com.cn/

相關(guān)文章

最新評(píng)論