大家好!這篇文章旨在幫助您改進專案資料類型的連接方式,使它們更可靠且更易於理解。
TLDR 對於那些匆忙的人:避免重複引用同一事物的類型和常數,並嘗試給它們提供暗示性的名稱(即使它們是簡單的字串或數字)。這將使您以後更容易識別、修改或刪除您的程式碼。
問題
假設您正在開發一個電子商務網站,並且您已將產品類型定義為:
export type ProductType = { id: string; name: string; price: number; };
在此類項目中,您可以透過簡單的函數輕鬆找到引用產品 id 的多種方式:
- const getProductById = (產品: ProductType[], id: string) =>; {...};
- const onProductPress = (productId: string) =>; {...};
更進階的情況,例如將產品的資料保存在狀態儲存中,或將 props 傳遞給 JS 框架中的其他元件
問題
現在讓我們用這個方法解決問題:
- 如果產品的 id 不是這麼簡單好記怎麼辦?如果它是類似 ab12-w35-s48-09 (代表例如供應商類別產品變體)怎麼辦?
- 如果(這是我的重點)您必須更改整個專案中所有出現的產品 ID 的類型怎麼辦? 如果您在不同的檔案中引用它時給它不同的名稱(例如 ProductId、product_id、pid 或 id),這可能會特別困難。您也不能只搜尋字串,因為您肯定會發現許多與它無關的出現。
潛在的解決方案
要解決問題一,您可以使用模板文字類型,這將使新產品ID 的類型為:${string}-${string}-${string}-${string} 。現在,在多個文件中重複此操作會很煩人,因此可以:
- 為 id 欄位建立自訂類型,並在 ProductType 中使用它:
type ProductIdType = `${string}-${string}-${string}-${string}`
如果需要,您也可以為每個字串建立並引用不同的類型,或引用您先前建立的其他類型。最後您將使用新類型:
(productId : ProductIdType) => {...}
- 或是你可以參考ProductType的id條目:
(productId : ProductType['id']) => {...}
這兩種方法都可以解決問題二:無論您在哪裡找到 ProductIdType 或 ProductType['id'],您都會知道您正在處理產品的 id,並且知道您應該替換它。
第一個解決方案可能看起來更友好,但現在您將擁有一個雙向結構,其中一個產品類型和另一個 id 類型,可以獨立使用。以下是所述結構的範例表示:
這無疑是一個較小的問題,但如果您更改/刪除 ProductType 的 id 條目,該更改不會反映在您的整個專案中。
然而,最後一種方法是我通常遵循的方法,因為它增加了數據的耦合(由於缺乏更好的詞)。現在,您對產品資料的所有參考都直接指向 ProductType:
結論
我並不是說您應該始終為所有資料建立類型。每當我看到自己重複引用相同的資料類型時,我通常會選擇存取原始資料類型,就像第二種方法一樣。
額外提示1: 您可以對const 應用相同的邏輯:如果您發現自己在多個位置重複相同的魔術數字或字串,最好給它一個正確的指定並使用它。
額外提示 2: 如果您想要選擇/排除某個類型的多個條目而不是重複它們,請使用「選擇」、「省略」和「排除」以及其他實用程式類型。
就這些了!我希望你喜歡我的帖子。請隨時留下您對此主題的回饋。
以上是改善專案中的耦合的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

WebStorm Mac版
好用的JavaScript開發工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器