搜尋
首頁web前端js教程過濾和鏈接功能JavaScript

Filtering and Chaining in Functional JavaScript

JavaScript 的多功能性:面向對象、命令式和函數式編程

JavaScript 的強大之處在於其多功能性,它支持面向對象編程、命令式編程和函數式編程。開發者可以根據項目需求和團隊偏好靈活切換編程範式。

ES5 引入了 mapreducefilter 等原生數組方法,極大地方便了函數式編程。其中,filter 方法能夠遍歷數組中的每個元素,根據指定的測試條件判斷是否將其添加到新的數組中。

使用 filter 方法簡化代碼

filter 方法使代碼更簡潔清晰。它遍歷數組中的每個元素,並應用測試函數。如果測試函數返回 true,則該元素將包含在 filter 方法返回的新數組中。

filter 方法與 ES5 的其他兩個函數式數組方法 mapreduce 協同工作,可以組合使用,創建簡潔高效的代碼,同時保持原始數組不變。

雖然 filter 方法可能比 for 循環略慢,但其帶來的代碼簡潔性和可維護性優勢使其成為推薦的實踐方式。隨著 JavaScript 引擎的優化,其性能有望進一步提升。

本文由 Dan Prince、Vildan Softic 和 Joan Yinn 審核。感謝所有 SitePoint 的同行評審者,讓 SitePoint 的內容達到最佳狀態!

Filtering and Chaining in Functional JavaScript

我喜歡 JavaScript 的一個原因是它的靈活性。它允許你使用面向對象編程、命令式編程,甚至函數式編程,並且可以根據你的當前需求以及團隊的偏好和期望在它們之間切換。

雖然 JavaScript 支持函數式技術,但它不像 Haskell 或 Scala 那樣針對純函數式編程進行優化。雖然我通常不會將我的 JavaScript 程序構建成 100% 的函數式,但我喜歡使用函數式編程的概念來幫助我保持代碼的簡潔性,並專注於設計易於重用和測試的代碼。

使用 filter 方法過濾數據集

ES5 的出現,使 JavaScript 數組繼承了一些使函數式編程更加方便的方法。 JavaScript 數組現在可以原生進行映射、規約和過濾。每種方法都遍歷數組中的每個項目,無需循環或局部狀態更改,即可執行分析,返回可立即使用或進一步操作的結果。在本文中,我想向你介紹過濾。過濾允許你評估數組的每個項目,並根據你傳入的測試條件,確定是否返回包含該元素的新數組。當你使用 Array 的 filter 方法時,你將得到另一個數組,該數組的長度與原始數組相同或更短,包含與你設置的條件匹配的原始數組中的子集項目。

使用循環演示過濾

一個可能受益於過濾的簡單問題的例子是將字符串數組限制為只有三個字符的字符串。這不是一個複雜的問題,我們可以使用普通的 JavaScript for 循環和不使用 filter 方法來輕鬆地解決它。它可能看起來像這樣:

var animals = ["cat","dog","fish"];
var threeLetterAnimals = [];
for (let count = 0; count < animals.length; count++) {
  if (animals[count].length === 3) {
    threeLetterAnimals.push(animals[count]);
  }
}
console.log(threeLetterAnimals); // ["cat", "dog"]

我們在這裡做的是定義一個包含三個字符串的數組,並創建一個空數組,我們可以在其中只存儲只有三個字符的字符串。我們定義了一個計數變量,在遍歷數組時在 for 循環中使用。每次我們遇到一個恰好有三個字符的字符串時,我們都會將其推入我們新的空數組中。完成後,我們只需記錄結果。沒有什麼能阻止我們在循環中修改原始數組,但是這樣做會永久丟失原始值。創建一個新數組並保持原始數組不變要乾淨得多。

使用 filter 方法

我們這樣做並沒有什麼技術上的錯誤,但是 Array 上 filter 方法的可用性使我們能夠使我們的代碼更加簡潔和直接。以下是如何使用 filter 方法完成完全相同的事情的示例:

var animals = ["cat","dog","fish"];
var threeLetterAnimals = [];
for (let count = 0; count < animals.length; count++) {
  if (animals[count].length === 3) {
    threeLetterAnimals.push(animals[count]);
  }
}
console.log(threeLetterAnimals); // ["cat", "dog"]

和以前一樣,我們從包含原始數組的變量開始,我們為將只包含具有三個字符的字符串的數組定義了一個新變量。但在這種情況下,當我們定義第二個數組時,我們將其直接賦值給將 filter 方法應用於原始 animals 數組的結果。我們將一個匿名內聯函數傳遞給 filter,該函數只有在其操作的值長度為 3 時才返回 true。 filter 方法的工作方式是遍歷數組中的每個元素並將測試函數應用於該元素。如果測試函數對該元素返回 true,則 filter 方法返回的數組將包含該元素。其他元素將被跳過。你可以看到代碼看起來簡潔了多少。即使事先不了解 filter 的作用,你也可以查看這段代碼並弄清楚它的意圖。函數式編程的一個好處是減少了要跟踪的局部狀態的數量,並限制了從函數內部修改外部變量,從而提高了代碼的簡潔性。在這種情況下,計數變量以及我們在遍歷原始數組時 threeLetterAnimals 數組所採用的各種狀態只是更多需要跟踪的狀態。使用 filter,我們已經設法消除了 for 循環以及計數變量。我們不像以前那樣多次更改新數組的值。我們只定義它一次,並為其分配從將我們的過濾器條件應用於原始數組中獲得的值。

其他格式化過濾器的方法

如果我們利用 const 聲明和匿名內聯箭頭函數,我們的代碼可以更簡潔。這些是 EcmaScript 6 (ES6) 功能,現在大多數瀏覽器和 JavaScript 引擎都原生支持。

var animals = ["cat","dog","fish"];
var threeLetterAnimals = animals.filter(function(animal) {
  return animal.length === 3;
});
console.log(threeLetterAnimals); // ["cat", "dog"]

雖然在大多數情況下最好超越舊語法,除非你需要使你的代碼與現有代碼庫匹配,但選擇它很重要。隨著我們變得越來越簡潔,我們的每一行代碼都變得越來越複雜。使 JavaScript 如此有趣的部分原因在於你可以嘗試使用許多方法來設計相同的代碼,以優化大小、效率、清晰度或可維護性,以適應團隊的偏好。但這同時也給團隊帶來了更大的負擔,需要創建共享的樣式指南並討論每個選擇的優缺點。在這種情況下,為了使我們的代碼更具可讀性和通用性,我們可能希望採用上面的匿名內聯箭頭函數並將其轉換為傳統的命名函數,然後將該命名函數直接傳遞到filter方法中。代碼可能如下所示:

const animals = ["cat","dog","fish"];
const threeLetterAnimals = animals.filter(item => item.length === 3);
console.log(threeLetterAnimals); // ["cat", "dog"]

我們在這裡所做的只是提取上面定義的匿名內聯箭頭函數並將其轉換為單獨的命名函數。正如我們所看到的,我們已經定義了一個純函數,它採用數組元素的適當值類型,並返回相同的類型。我們可以直接將該函數的名稱作為條件傳遞給 filter 方法。

(後續內容,關於 mapreduce 和鍊式調用的部分,由於篇幅限制,請自行根據原文補充。) 保持原文的圖片和格式。

以上是過濾和鏈接功能JavaScript的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
在JavaScript中替換字符串字符在JavaScript中替換字符串字符Mar 11, 2025 am 12:07 AM

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

構建您自己的Ajax Web應用程序構建您自己的Ajax Web應用程序Mar 09, 2025 am 12:11 AM

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

10個JQuery Fun and Games插件10個JQuery Fun and Games插件Mar 08, 2025 am 12:42 AM

10款趣味橫生的jQuery遊戲插件,讓您的網站更具吸引力,提升用戶粘性!雖然Flash仍然是開發休閒網頁遊戲的最佳軟件,但jQuery也能創造出令人驚喜的效果,雖然無法與純動作Flash遊戲媲美,但在某些情況下,您也能在瀏覽器中獲得意想不到的樂趣。 jQuery井字棋遊戲 遊戲編程的“Hello world”,現在有了jQuery版本。 源碼 jQuery瘋狂填詞遊戲 這是一個填空遊戲,由於不知道單詞的上下文,可能會產生一些古怪的結果。 源碼 jQuery掃雷遊戲

如何創建和發布自己的JavaScript庫?如何創建和發布自己的JavaScript庫?Mar 18, 2025 pm 03:12 PM

文章討論了創建,發布和維護JavaScript庫,專注於計劃,開發,測試,文檔和促銷策略。

jQuery視差教程 - 動畫標題背景jQuery視差教程 - 動畫標題背景Mar 08, 2025 am 12:39 AM

本教程演示瞭如何使用jQuery創建迷人的視差背景效果。 我們將構建一個帶有分層圖像的標題橫幅,從而創造出令人驚嘆的視覺深度。 更新的插件可與JQuery 1.6.4及更高版本一起使用。 下載

Matter.js入門:簡介Matter.js入門:簡介Mar 08, 2025 am 12:53 AM

Matter.js是一個用JavaScript編寫的2D剛體物理引擎。此庫可以幫助您輕鬆地在瀏覽器中模擬2D物理。它提供了許多功能,例如創建剛體並為其分配質量、面積或密度等物理屬性的能力。您還可以模擬不同類型的碰撞和力,例如重力摩擦力。 Matter.js支持所有主流瀏覽器。此外,它也適用於移動設備,因為它可以檢測觸摸並具有響應能力。所有這些功能都使其值得您投入時間學習如何使用該引擎,因為這樣您就可以輕鬆創建基於物理的2D遊戲或模擬。在本教程中,我將介紹此庫的基礎知識,包括其安裝和用法,並提供一

使用jQuery和Ajax自動刷新DIV內容使用jQuery和Ajax自動刷新DIV內容Mar 08, 2025 am 12:58 AM

本文演示瞭如何使用jQuery和ajax自動每5秒自動刷新DIV的內容。 該示例從RSS提要中獲取並顯示了最新的博客文章以及最後的刷新時間戳。 加載圖像是選擇

如何在瀏覽器中優化JavaScript代碼以進行性能?如何在瀏覽器中優化JavaScript代碼以進行性能?Mar 18, 2025 pm 03:14 PM

本文討論了在瀏覽器中優化JavaScript性能的策略,重點是減少執行時間並最大程度地減少對頁面負載速度的影響。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
2 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
2 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),