過濾和鏈接功能JavaScript
JavaScript 的多功能性:面向對象、命令式和函數式編程
JavaScript 的強大之處在於其多功能性,它支持面向對象編程、命令式編程和函數式編程。開發者可以根據項目需求和團隊偏好靈活切換編程範式。
ES5 引入了 map
、reduce
和 filter
等原生數組方法,極大地方便了函數式編程。其中,filter
方法能夠遍歷數組中的每個元素,根據指定的測試條件判斷是否將其添加到新的數組中。
使用 filter
方法簡化代碼
filter
方法使代碼更簡潔清晰。它遍歷數組中的每個元素,並應用測試函數。如果測試函數返回 true
,則該元素將包含在 filter
方法返回的新數組中。
filter
方法與 ES5 的其他兩個函數式數組方法 map
和 reduce
協同工作,可以組合使用,創建簡潔高效的代碼,同時保持原始數組不變。
雖然 filter
方法可能比 for
循環略慢,但其帶來的代碼簡潔性和可維護性優勢使其成為推薦的實踐方式。隨著 JavaScript 引擎的優化,其性能有望進一步提升。
本文由 Dan Prince、Vildan Softic 和 Joan Yinn 審核。感謝所有 SitePoint 的同行評審者,讓 SitePoint 的內容達到最佳狀態!
我喜歡 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 方法。
(後續內容,關於 map
、reduce
和鍊式調用的部分,由於篇幅限制,請自行根據原文補充。) 保持原文的圖片和格式。
以上是過濾和鏈接功能JavaScript的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

JavaScript在Web開發中的主要用途包括客戶端交互、表單驗證和異步通信。 1)通過DOM操作實現動態內容更新和用戶交互;2)在用戶提交數據前進行客戶端驗證,提高用戶體驗;3)通過AJAX技術實現與服務器的無刷新通信。

JavaScript在現實世界中的應用包括前端和後端開發。 1)通過構建TODO列表應用展示前端應用,涉及DOM操作和事件處理。 2)通過Node.js和Express構建RESTfulAPI展示後端應用。

理解JavaScript引擎內部工作原理對開發者重要,因為它能幫助編寫更高效的代碼並理解性能瓶頸和優化策略。 1)引擎的工作流程包括解析、編譯和執行三個階段;2)執行過程中,引擎會進行動態優化,如內聯緩存和隱藏類;3)最佳實踐包括避免全局變量、優化循環、使用const和let,以及避免過度使用閉包。

Python和JavaScript在社區、庫和資源方面的對比各有優劣。 1)Python社區友好,適合初學者,但前端開發資源不如JavaScript豐富。 2)Python在數據科學和機器學習庫方面強大,JavaScript則在前端開發庫和框架上更勝一籌。 3)兩者的學習資源都豐富,但Python適合從官方文檔開始,JavaScript則以MDNWebDocs為佳。選擇應基於項目需求和個人興趣。

Python和JavaScript在開發環境上的選擇都很重要。 1)Python的開發環境包括PyCharm、JupyterNotebook和Anaconda,適合數據科學和快速原型開發。 2)JavaScript的開發環境包括Node.js、VSCode和Webpack,適用於前端和後端開發。根據項目需求選擇合適的工具可以提高開發效率和項目成功率。
