精品秘无码一区二区三区老师-精品秘一区二三区免费雷安-精品蜜桃秘一区二区三区-精品蜜桃秘一区二区三区粉嫩-精品蜜桃一区二区三区-精品蜜臀国产aⅴ一区二区三区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

只有 2% 的開發(fā)者知道的 7 個驚人的 JavaScript 數(shù)組方法

admin
2025年1月21日 10:0 本文熱度 390

如果你曾經(jīng)想過:“我不需要除了for循環(huán)和map()之外的任何東西”,聽著,因?yàn)槲乙嬖V你你錯得有多離譜。

以下是 7 個被低估的數(shù)組方法,可能會讓你大吃一驚——是的,它們用起來出奇地有趣。

1. copyWithin()

想象一下復(fù)制一片披薩,但不是得到一片新的,而是笨拙地把它塞回同一個盒子里。

copyWithin()的作用有點(diǎn)像這樣——它從數(shù)組中取出一部分并將其復(fù)制到同一個數(shù)組中的另一個位置。它不會增加長度,所以不會有額外的“卡路里”(或元素)。

const arr = [12345];
arr.copyWithin(03); // [4, 5, 3, 4, 5]

在這里,從索引 3(4, 5)的元素被復(fù)制到索引 0 開始,替換了12。你還可以指定一個可選的結(jié)束索引來限制被復(fù)制的部分。

2. at()with()

這兩個是新出現(xiàn)的很酷的方法。at()首先出現(xiàn),為我們提供了一種簡潔的訪問元素的方式,特別是使用負(fù)索引。然后with()在 2023 年加入,自豪地為修改數(shù)組元素提供了不可變的替代方法。

const colors = ['red''blue''green''yellow'];

console.log(colors.at(-1)); // 'yellow'
console.log(colors.with(1'purple')); // ['red', 'purple', 'green', 'yellow']

at()在你需要處理數(shù)組末尾時很有用,而with()確保在你進(jìn)行更新時原始數(shù)組保持不變。

3. reduceRight()

每個人都知道reduce()——它就像數(shù)組方法中的瑞士軍刀。但是你有沒有希望過可以反過來呢?那就來看看reduceRight(),它從右到左處理數(shù)組。

const arr = ['a''b''c''d'];
const result = arr.reduceRight((acc, curr) => acc + curr); 
console.log(result); // 'dcba'

在這個例子中,reduceRight()從末尾開始組合元素,得到一個反轉(zhuǎn)的連接結(jié)果。

4. findLast()

向 ES13 中保守得最好的秘密之一問好。findLast()的工作方式就像find(),但它從數(shù)組的末尾開始搜索。

這在你知道要搜索的項(xiàng)目更接近尾部時特別有用。

const nums = [1234567];
console.log(nums.findLast(n => n % 2 === 0)); // 6

與從開頭搜索的find()不同,findLast()從末尾開始,使其在特定場景中非常理想,例如查找特定類型值的最后一次出現(xiàn)。

5. toSorted(), toReversed(), toSpliced()

來認(rèn)識一下sort(), reverse()splice()的不可變“表親”。這些 ES2023 新增的方法讓你在不改變原始數(shù)據(jù)的情況下操作數(shù)組。

為什么你應(yīng)該關(guān)心?因?yàn)楫?dāng)你的變量不會在你背后神秘地改變時,調(diào)試會容易一百萬倍。

const arr = [31415];

// 不可變排序
console.log(arr.toSorted()); // [1, 1, 3, 4, 5]
console.log(arr); // [3, 1, 4, 1, 5]

// 不可變反轉(zhuǎn)
console.log(arr.toReversed()); // [5, 1, 4, 1, 3]
console.log(arr); // [3, 1, 4, 1, 5]

這些方法讓你在保持原始數(shù)組不變的情況下進(jìn)行更改,確保代碼更具可預(yù)測性和可調(diào)試性。

6. lastIndexOf()

indexOf()被低估的“兄弟姐妹”,lastIndexOf()正如你所想——它在數(shù)組中查找元素的最后一次出現(xiàn)。你甚至可以指定在哪里停止搜索。

const arr = ['apple''banana''cherry''apple'];

// 查找'apple'的最后一次出現(xiàn)
console.log(arr.lastIndexOf('apple')); // 3

// 限制搜索到前 3 個元素
console.log(arr.lastIndexOf('apple'2)); // 0

當(dāng)你處理可能包含重復(fù)元素的數(shù)組,并且你特別需要最后一個實(shí)例時,這個方法很有幫助。

7. flatMap()

當(dāng)你可以在一個流暢的操作中把它們結(jié)合起來時,為什么要滿足于map()flat()呢?flatMap()轉(zhuǎn)換你的數(shù)組并將結(jié)果展平一層。

const arr = [12, [3], 4];

// 在一步中進(jìn)行映射和展平
console.log(arr.flatMap(x => [x * 2])); // [2, 4, 6, 8]

就像一次提交解決兩個問題——更干凈、更快,也更令人滿意。

最終思考

這些數(shù)組方法可能不像filter()push()那么流行,但它們非常強(qiáng)大。試試看,誰知道呢?你可能會給你的同事留下深刻印象——或者至少在代碼審查時讓他們感到困惑。

記住,你知道得越多,循環(huán)就越少!

快樂編碼!


原文地址:https://medium.com/@arnoldgunter/7-amazing-javascript-array-methods-that-only-2-of-developers-know-simple-and-surprising-64f8f21231e4
作者:Arnold Gunter


該文章在 2025/1/21 10:00:00 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場、車隊(duì)、財務(wù)費(fèi)用、相關(guān)報表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 亚洲av无码专区亚洲av伊甸园 | 国产精品日韩欧美一区二区 | 精品国产三级a∨在线无码 精品国产三级a∨在线欧美 | 无码人妻丰满熟妇奶水区码 | 午夜片神马影院福利 | 一区二区三区福利视频免费观看 | 麻豆精品成人免费国产片 | 中文国产成人精品久久不卡 | 91久久国产 | 国产无遮挡裸体免费视频 | 麻豆久久久久久久 | 久久精品国产69国产精品亚洲 | 色综合久久精品亚洲国产 | 五月丁香合缴情在线看 | 亚洲国产高清在线一区二区三区 | 欧美人妻aⅴ中文字幕不卡 欧美人妻aⅴ中文字幕 | 国产乱伦精品一区二区三区免费观看 | 免费精品国产人妻国语 | 久久精品国产曰本波多野结衣国产婷婷一区二区三区 | 成人精品午夜无码免费视小黄人 | 中国国产免费一级片 | 亚洲男人网在线 | 欧美精品高清无码 | 无码人妻精品一区二区蜜桃网站 | 无码人妻视频一区二区 | 午夜福利国产成人无码gif动图 | 精品无码久久久久久久久水蜜桃 | 韩国三级日本三级香港黄 | 亚洲精品久久久一区二区三区 | 国产真实乱对白精彩 | 亚洲精品国产成人99久久6 | 久久久久久好爽爽久久 | 亚洲国产二区三区久久高清大蕉 | 麻豆果冻国产剧情av在线播放 | 国产又爽又大又黄A片软件 国产又爽又大又黄A片图片 | 人妻av区乱码 | 多人交换做爰波多野结衣图片 | 熟女人妻中出系列战争剧 | 麻豆国产亚洲视在线视频 | 野花社区wwW高清视频 | 久久久久亚洲精品无码系列 |