国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Javascript數(shù)組系列二之迭代方法2

fredshare / 3467人閱讀

摘要:該方法接受兩個參數(shù),一個是元素每一項執(zhí)行的回調(diào)函數(shù),一個是可選參數(shù),回調(diào)函數(shù)運行時的值。

今天我們來繼續(xù) Javascript 數(shù)組系列的文章,上文 《Javascript數(shù)組系列二之迭代方法1》 我們說到一些數(shù)組的迭代方法,我們在開發(fā)項目實戰(zhàn)的過程中熟練的使用可以大大提高我們的開發(fā)效率以及數(shù)據(jù)的處理。接下來我們繼續(xù)來講解其他的一些迭代的方法。

天也黑了,時間也不早了,話不多說,擼起袖子干起來!

數(shù)組的迭代方法 reduce

該方法對一個累加值和數(shù)組中的每一個元素執(zhí)行給定的函數(shù),返回一個函數(shù)累計處理的結(jié)果。

乍一看定義好像不是很好理解,來看一個例子你就會立刻明白,簡單來說該方法就是對數(shù)組進行合并操作。

const numbers = [1, 2, 3, 4, 5];
const result = numbers.reduce((sum, value) => sum + value);
console.log(result); //15
這里值得注意的是,reduce 方法的執(zhí)行順序是從左到右,為什么特意指出,因為下面我們會介紹一個從右到左的方法(reduceRight),先行了解下。

從上面的例子我們能看出「reduce」方法的作用,但是可能我們還不清楚具體的執(zhí)行過程是怎么樣的,繼續(xù)走起!

還是按照以往的慣例,我們先來看看「reduce」的參數(shù)和語法

該方法接受兩個參數(shù),一個是元素每一項執(zhí)行的回調(diào)函數(shù);一個是可選的參數(shù),作為第一次調(diào)用函數(shù)的初始值(也就是第一次的累加值)

傳入的回調(diào)函數(shù)會接受個參數(shù)分別是:調(diào)用函數(shù)返回的累計值(accumulator),數(shù)組中當前處理的元素(currentValue),當前處理元素的索引(currentIndex,可選),數(shù)組本身(array,可選)。

//語法
array.reduce(callback[, initialValue])
array.reduce(callback(accumulator, currentValue, currentIndex, array){
    //return 合并操作
});

參數(shù)與語法認清之后,先來看兩個例子

//例子1
const numbers = [1, 2, 3, 4, 5];
const result = numbers.reduce((accumulator, currentValue, currentIndex) => {
    console.log(currentIndex); //1, 2, 3, 4
    return accumulator + currentValue;
});
console.log(result); //15

//例子2
const newResult = numbers.reduce((accumulator, currentValue, currentIndex) => {
    console.log(currentIndex);  //0, 1, 2, 3, 4
    return accumulator + currentValue;
}, 10);
console.log(newResult); //25

從以上兩個例子中我們也看到一些不同的輸出結(jié)果,原因是因為我們給定了一個初始值之后,方法開始執(zhí)行的位置發(fā)生變化,那么是如何變化的呢?

這里存在兩種情況:

如果我們在使用「reduce」方法的時候,提供可選的初始值(initialValue),在回調(diào)函數(shù)第一次執(zhí)行的時候,第一次的累計值會默認取值為給定的初始值,當前參與計算的元素會從數(shù)組的第一項開始

(即:accumulator = initialValue,currentValue = array[0])

如果我們在使用「reduce」方法的時候,沒有提供初始值(initialValue),那么在回調(diào)函數(shù)第一次執(zhí)行的時候,第一次的累計值為數(shù)組的第一項,當前參與計算的值為數(shù)組的第二項(即: accumulator = array[0],

currentValue = array[1])

簡單來說如果我們提供初始值,回調(diào)函數(shù)會從數(shù)組的第二項(index=0)開始執(zhí)行,反之回調(diào)函數(shù)會從數(shù)組的第一項開始執(zhí)行(index=1),這就是上面例子中輸出索引的結(jié)果不同的原因。

說了這么多,大家肯定很清楚了,那最后我們來看看 「reduce」 方法的兼容性,還是直接上圖。

reduceRight

從名字我們已經(jīng)看出「reduceRight」與「reduce」肯定有扯不清的關(guān)系了。上面我們也說到「reduce」方法的執(zhí)行順序是從左到右。

而「reduceRight」方法的執(zhí)行順序為從右到左,除了在這一點上與「reduce」不同之外,其他地方與「reduce」一毛一樣,所以我們就不做過多解釋了,看一個簡單的例子即可。

const numbers = [1, 2, 3, 4, 5];
const result = numbers.reduceRight((accumulator, currentValue, currentIndex) => {
    console.log(currentIndex); //3, 2, 1, 0
    return accumulator + currentValue;
});
console.log(result); //15
find

該方法對數(shù)組的每一個元素執(zhí)行給定的函數(shù),返回滿足條件的元素,如果發(fā)現(xiàn)滿足條件的值會立即返回當前元素,如果未發(fā)現(xiàn)滿足條件的元素則返回 undefined。

該方法接受兩個參數(shù),一個是元素每一項執(zhí)行的回調(diào)函數(shù),一個是可選參數(shù),回調(diào)函數(shù)運行時 this 的值。

傳入的回調(diào)函數(shù)會接受三個參數(shù)分別是:數(shù)組中的元素(item),元素的索引(index,可選),數(shù)組本身(array,可選)。

//語法
array.find(callback[, this])
array.find(callback(item, index, array){
    //return 執(zhí)行的操作
});

//例子
const numbers = [4, 9, 16, 25, 29];
const result = numbers.find((item, index)=> {
    console.log(index); //0, 1, 2
    return item > 10;
});
console.log(result); //16
根據(jù)案例中打印的結(jié)果與最后返回的結(jié)果來看,當找到滿足條件的元素時會立刻返回結(jié)果,并終止函數(shù)的執(zhí)行。可以理解為「find」方法就是在眾多數(shù)據(jù)中找到一個我們想要的。

讓我們來看看 「find」方法的兼容性,繼續(xù)直接上圖。

findIndex

通過「find」方法聰明的你們肯定會發(fā)現(xiàn)「findIndex」用法。

是的「findIndex」的用法與 「find」基本相同,不同的是「findIndex」返回的是我們滿足條件元素的索引,而「find」返回的是元素。

既然如此我們就不做過多介紹,還是利用我們在「find」方法中使用的案例。

//例子
const numbers = [4, 9, 16, 25, 29];
const result = numbers.findIndex((item)=> {
    return item > 10;
});
console.log(result); //2

雖說兩者的用法基本相同,但是在沒有得到滿足我們條件的元素時,其兩者返回的結(jié)果會略有不同。一個返回 undefined,一個返回 -1。

const numbers = [4, 9, 16, 25, 29];
const result = numbers.find((item)=> {
    return item > 30;
});
console.log(result); //undefined
const resultIndex = numbers.findIndex((item)=> {
    return item > 30;
});
console.log(resultIndex); //-1
indexOf

該方法會對給定的一個值在數(shù)組中進行查找,如果找到相同的元素則返回元素的索引,否則返回 -1 。

該方法接受兩個參數(shù):一個是要查找的元素(searchElement),一個是查找開始的位置(fromIndex,可選),默認值為 0 。

//語法
arr.indexOf(searchElement)
arr.indexOf(searchElement[, fromIndex = 0])

//案例
const numbers = [2, 3, 2, 4, 2];
console.log(numbers.indexOf(2)); //0
console.log(numbers.indexOf("2")); //-1
console.log(numbers.indexOf(2, 1)); //2
console.log(numbers.indexOf(2, -1)); //4

「indexOf」方法有幾點需要我們注意的地方。

在方法執(zhí)行查找的過程中使用的是嚴格相等(===),案例中查找 "2" 時返回 -1 ,就是這個原因,如果不知道 == 與 === 有什么區(qū)別的小伙伴可以自己查閱下資料進行了解。

關(guān)于第二個參數(shù) fromIndex,如果當 fromIndex 的數(shù)值大于或者等于執(zhí)行的數(shù)組長度時,就會返回 -1,因為沒有地方查找了。如果查找的數(shù)值為負數(shù),則會從數(shù)組的后面開始查找。

要注意的是數(shù)組的末尾的索引是從 -1 開始的;例如:-1從數(shù)組的最后一個元素開始,-2從數(shù)組的倒數(shù)第二個元素開始。

非常重要的一點是不管 fromIndex 的數(shù)值為正數(shù)還是負數(shù)「indexOf」方法的查找順序都是從前向后執(zhí)行的,案例中最后一個方法輸出的是 4 而不是 2 的原因。

那有沒有從后向前查找元素的方法呢?答案是肯定的,后面我們會繼續(xù)說的,在這之前我們先來看一個我們在項目開發(fā)過程中經(jīng)常使用的一個例子。

我們就利用上面說到的 reduce 與 indexOf 來實現(xiàn)一個數(shù)組簡單去重的方法

const numbers = [2, 3, 2, 4, 2, 3, 1, 4];
const result = numbers.reduce((prev, current) => {
    if (prev.indexOf(current) === -1) {
        prev.push(current);
    }
    return prev;
}, []);
console.log(result); //[2, 3, 4, 1]

最后我們再來看看「indexOf」方法的兼容性。

lastIndexOf

「lastIndexOf」與「indexOf」用法相同;不同的是前者
是從后向前查找,后者是從前向后查找。

const numbers = [2, 3, 2, 4, 2];
console.log(numbers.lastIndexOf(2)); //4
console.log(numbers.lastIndexOf("2")); //-1
console.log(numbers.lastIndexOf(2, 1)); //0
console.log(numbers.lastIndexOf(2, -1)); //4
總結(jié)

我們花了兩篇文章說了數(shù)組的一系列迭代方法,其實包括 forEach、map、filter、find、reduce等等,從中我們可以看出數(shù)組在 Javascript 中的地位,同時數(shù)組在我們實際的項目中也扮演著重要的地位。如果文章你喜歡,可以繼續(xù)關(guān)注,后面我們還會說到數(shù)組的其他一些操作方法也同樣有著很重要的作用。

關(guān)注微信公眾號:六小登登。領(lǐng)取全套學(xué)習(xí)資源

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/97707.html

相關(guān)文章

  • Javascript數(shù)組系列二之迭代方法1

    摘要:我們在數(shù)組系列一之棧與隊列中介紹了一些數(shù)組的用法。該方法接受兩個參數(shù),一個是元素每一項執(zhí)行的回調(diào)函數(shù),一個是可選參數(shù),回調(diào)函數(shù)運行時的值。今天我們就說這么多,希望你有所收獲,接下來還請繼續(xù)關(guān)注,我們繼續(xù)來說數(shù)組的其他一系列的方法。 我們在《avascript數(shù)組系列一之棧與隊列》中介紹了一些數(shù)組的用法。比如:數(shù)組如何表現(xiàn)的和「棧」一樣,用什么方法表現(xiàn)的和「隊列」一樣等等一些方法,因為 ...

    tylin 評論0 收藏0
  • Javascript數(shù)組系列五之增刪改和強大的 splice()

    摘要:刪除數(shù)組元素的開始索引需要刪除元素的個數(shù),插入數(shù)組的元素語法因為參數(shù)變化多樣,我們主要從三個方面來展示的用法。 今天是我們介紹數(shù)組系列文章的第五篇,也是我們數(shù)組系列的最后一篇文章,只是數(shù)據(jù)系列的結(jié)束,所以大家不用擔(dān)心,我們會持續(xù)的更新干貨文章。 生命不息,更新不止! 今天我們就不那么多廢話了,直接干貨開始。 我們在《Javascript數(shù)組系列一之棧與隊列》中描述我們是如何利用 pus...

    chavesgu 評論0 收藏0
  • python綜合學(xué)習(xí)二之多進程

    摘要:本節(jié)講學(xué)習(xí)的多進程。和之前的的不同點是丟向的函數(shù)有返回值,而的沒有返回值。所以接下來讓我們來看下這兩個進程是否會出現(xiàn)沖突。 本節(jié)講學(xué)習(xí)Python的多進程。 一、多進程和多線程比較 多進程 Multiprocessing 和多線程 threading 類似, 他們都是在 python 中用來并行運算的. 不過既然有了 threading, 為什么 Python 還要出一個 multip...

    gityuan 評論0 收藏0
  • Map學(xué)習(xí)二之LinkedHash,HashTable,計算一個給定字符串的每個字符出現(xiàn)的次數(shù)

    package com.itheima.demo03.Map; import java.util.HashMap;import java.util.LinkedHashMap; /* java.util.LinkedHashMap entends HashMap Map 接口的哈希表和鏈接列表實現(xiàn),具有可預(yù)知的迭代順序。 底層原理: 哈希表+鏈表(記錄元素的順序) */public cla...

    Rocture 評論0 收藏0
  • clay教程二之布局的使用

    摘要:上圖是布局的計算模型。刪除方法刪除的只是布局保存的數(shù)據(jù),然后重繪畫面,如果你需要畫面平滑改變,修改繪圖實現(xiàn)方法即可,這里不再贅述。 作者:心葉時間:2018-11-06 14:47 clay項目Github地址:https://github.com/yelloxing/... 喜歡本項目的可以在github上給給star。 在繪制一些常見圖形的時候,比如關(guān)系圖,單個結(jié)點或連線并不難,麻...

    Forest10 評論0 收藏0

發(fā)表評論

0條評論

fredshare

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<