成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

[譯]如何更好的使用javascript數(shù)組

Bmob / 2037人閱讀

摘要:為了避免這種情況,我推薦他同一樣需要一個(gè)回調(diào)函數(shù)參數(shù),并且返回第一個(gè)能夠滿足回調(diào)函數(shù)參數(shù)的那一項(xiàng)。

趕緊閱讀讀此文,我保證,在過(guò)去的幾個(gè)月里我,我確定我在數(shù)組問(wèn)題上犯過(guò)4次錯(cuò)誤。于是我寫(xiě)下這篇文章,閱讀這篇文章可以讓你更準(zhǔn)確的使用javascript數(shù)組的一些方法

使用Array.includes替代 Array.indexOf

“如果你在數(shù)組中搜索某個(gè)元素,那么請(qǐng)使用Array.indexOf” ,我記得在學(xué)習(xí)javascript時(shí)看到過(guò)這個(gè)句子,毫無(wú)疑問(wèn),這句話很對(duì)。

MDN文檔上這樣描述 rray.indexOf“返回第一個(gè)被搜索到的元素的下標(biāo)(索引)” ,所以如果你想要搜索某個(gè)元素的下標(biāo),那么Array.indexOf可以很好的解決。

但是,如果我們想查看一個(gè)數(shù)組中是否包涵某個(gè)元素該如何做呢。就像yes/no這樣的問(wèn)題,也就是布爾值。這里我們推薦使用返回布爾值的Array.includes方法。

const persons = ["jay","leinov","jj","nico"];

console.log(persons.indexOf("leinov"));
// 1

console.log(persons.indexOf("beyond"));
// -1


 console.log(persons.includes("leinov"));
// true

console.log(persons.includes("beyond"));
// false
使用Array.find代替Array.filter

Array.filter是一個(gè)非常有用的方法,它通過(guò)一個(gè)數(shù)組的回調(diào)參數(shù)創(chuàng)建一個(gè)新的數(shù)組,正如他的名字所示,我們使用它過(guò)濾出一個(gè)更短的數(shù)組

但是 如果我們明確的知道回調(diào)函數(shù)返回的只是數(shù)組中的一項(xiàng),這樣的話我不推薦使用他,例如,當(dāng)使用的回調(diào)參數(shù)過(guò)濾的是一個(gè)唯一的id,這種情況,Array.filter返回一個(gè)新的包涵這一項(xiàng)的數(shù)組。尋找一個(gè)特殊的id,我們目的只想取一項(xiàng)出來(lái),這個(gè)返回的數(shù)組就是無(wú)用的。

接下來(lái)我們看下性能,為了返回能夠匹配回調(diào)函數(shù)的每一項(xiàng),Array.filter必須檢索整個(gè)數(shù)組,此外讓我們想象下,我們有數(shù)百個(gè)項(xiàng)滿足我們的回調(diào)參數(shù)函數(shù),我們過(guò)濾的數(shù)組就非常大了。

為了避免這種情況,我推薦Array.find ,他同Array.filter一樣需要一個(gè)回調(diào)函數(shù)參數(shù),并且返回第一個(gè)能夠滿足回調(diào)函數(shù)參數(shù)的那一項(xiàng)。并且Array.find 在滿足篩選后停止篩選,不會(huì)檢索整個(gè)數(shù)組。

use strict";

const singers = [
  { id: 1, name: "周杰倫" },
  { id: 2, name: "李建" },
  { id: 3, name: "庾澄慶" },
  { id: 4, name: "謝霆鋒" },
  { id: 5, name: "周杰倫" },
];

function getSinger(name) {
  return signer => signer.name === name;
}

console.log(singers.filter(getSinger("周杰倫")));
// [
//   { id: 1, name: "周杰倫" },
//   { id: 5, name: "周杰倫" },
// ]

console.log(characters.find(getSinger("周杰倫")));
// { id: 1, name: "周杰倫" }
使用Array.some代替Array.find

我承認(rèn)經(jīng)常在這上面犯錯(cuò),然后,我的一個(gè)好朋友提醒我看下MDN文檔去尋找一個(gè)更好的方式解決,這點(diǎn)跟上面的Array.indexOf/Array.includes很相似

在前面提到 Array.find 需要一個(gè)回調(diào)函數(shù)作為參數(shù)來(lái)返回一個(gè)滿足的元素。如果我們需要知道數(shù)組是否包涵某個(gè)值時(shí),Array.find是最好的方式嗎。或許不是,因?yàn)榉祷氐氖且粋€(gè)值,不是一個(gè)布爾值。

在這種情況下,我推薦使用Array.some,它返回的是一個(gè)是否滿足回調(diào)參數(shù)的布爾值

"use strict";

const characters = [
  { id: 1, name: "ironman", env: "marvel" },
  { id: 2, name: "black_widow", env: "marvel" },
  { id: 3, name: "wonder_woman", env: "dc_comics" },
];

function hasCharacterFrom(env) {
  return character => character.env === env;
}

console.log(characters.find(hasCharacterFrom("marvel")));
// { id: 1, name: "ironman", env: "marvel" }

console.log(characters.some(hasCharacterFrom("marvel")));
// true
使用Array.reduce 代替 Array.filter and Array.map

讓我們來(lái)看看Array.reduce,Array.reduce并不太好理解,但是如果我們執(zhí)行Array.filter,Array.map感覺(jué)我們好像錯(cuò)過(guò)了什么。

我的意思是,我們檢索了數(shù)組兩次,第一次過(guò)濾和創(chuàng)建了一個(gè)短的數(shù)組,第二次創(chuàng)建了一個(gè)新的包涵我們過(guò)濾獲取到的數(shù)組。為了獲取結(jié)果我們使用了兩個(gè)數(shù)組方法,每個(gè)方法都有一個(gè)回調(diào)函數(shù)和一個(gè)數(shù)組,其中一個(gè)Array.filter創(chuàng)建的我們之后是用不到的。

為了避免這個(gè)性能的問(wèn)題,我建議使用Array.reduce來(lái)代替。相同的結(jié)果,更好的代碼。Aaray.reduce允你篩選和添加滿足的項(xiàng)目到累加器中。例如,這個(gè)累加器可以是一個(gè)數(shù)字增量,一個(gè)要填充的對(duì)象,一個(gè)字符串或一個(gè)數(shù)組。

在我們之前的例子中,我們一直在使用Array.map,所以我建議使用Array.reduce來(lái)使用累加器來(lái)連接數(shù)組。在下面的示例中,根據(jù)env的值,我們將將其添加到累加器中,或者將此累加器保留為原來(lái)的值。

"use strict";

const characters = [
  { name: "ironman", env: "marvel" },
  { name: "black_widow", env: "marvel" },
  { name: "wonder_woman", env: "dc_comics" },
];

console.log(
  characters
    .filter(character => character.env === "marvel")
    .map(character => Object.assign({}, character, { alsoSeenIn: ["Avengers"] }))
);
// [
//   { name: "ironman", env: "marvel", alsoSeenIn: ["Avengers"] },
//   { name: "black_widow", env: "marvel", alsoSeenIn: ["Avengers"] }
// ]

console.log(
  characters
    .reduce((acc, character) => {
      return character.env === "marvel"
        ? acc.concat(Object.assign({}, character, { alsoSeenIn: ["Avengers"] }))
        : acc;
    }, [])
)
// [
//   { name: "ironman", env: "marvel", alsoSeenIn: ["Avengers"] },
//   { name: "black_widow", env: "marvel", alsoSeenIn: ["Avengers"] }
// ]
原文:Here’s how you can make better use of JavaScript arrays
如有哪里翻譯錯(cuò)誤請(qǐng)指正 3Q

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

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/97363.html

相關(guān)文章

  • [] 如何恰當(dāng)?shù)貙W(xué)習(xí) JavaScript

    摘要:原文鏈接恰當(dāng)?shù)貙W(xué)習(xí)適合第一次編程和非的程序員持續(xù)時(shí)間到周前提無(wú)需編程經(jīng)驗(yàn)繼續(xù)下面的課程。如果你沒(méi)有足夠的時(shí)間在周內(nèi)完成全部的章節(jié),學(xué)習(xí)時(shí)間盡力不要超過(guò)周。你還不是一個(gè)絕地武士,必須持續(xù)使用你最新學(xué)到的知識(shí)和技能,盡可能地經(jīng)常持續(xù)學(xué)習(xí)和提高。 原文鏈接:How to Learn JavaScript Properly 恰當(dāng)?shù)貙W(xué)習(xí) JavaScript (適合第一次編程和非 JavaSc...

    Jason 評(píng)論0 收藏0
  • 」編寫(xiě)更好 JavaScript 條件式和匹配條件技巧

    摘要:通常情況下,面向?qū)ο缶幊套屛覀兊靡员苊鈼l件式,并代之以繼承和多態(tài)。同時(shí),使用條件式簡(jiǎn)寫(xiě)來(lái)表示值。因此,對(duì)于以這種方式編寫(xiě)的代碼,你需要使用進(jìn)行編譯。 原文地址:Tips and Tricks for Better JavaScript Conditionals and Match Criteria 原文作者:Milos Protic 介紹 如果你像我一樣樂(lè)于見(jiàn)到整潔的代碼,那么你...

    honmaple 評(píng)論0 收藏0
  • [] 在你學(xué)習(xí) React 之前必備 JavaScript 基礎(chǔ)

    摘要:前言在理想的狀態(tài)下,你可以在深入了解之前了解和開(kāi)發(fā)的所有知識(shí)。繼承另一個(gè)類的類,通常稱為類或類,而正在擴(kuò)展的類稱為類或類。這種類型的組件稱為無(wú)狀態(tài)功能組件。在你有足夠的信心構(gòu)建用戶界面之后,最好學(xué)習(xí)。 原文地址:JavaScript Basics Before You Learn React 原文作者: Nathan Sebhastian 寫(xiě)在前面 為了不浪費(fèi)大家的寶貴時(shí)間,在開(kāi)...

    Chaz 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<