搜尋
首頁web前端js教程合理設計React元件,讓程式碼更美觀! !

合理設計React元件,讓程式碼更美觀! !

react的目的是將前端頁面元件化,並用狀態機的思考模式去控制元件。元件和元件之間肯定是有關係得,透過合理得元件設計,給每一個元件劃定適合得邊界,可以有效降低當我們對頁面進行重構時對其他元件之間得影響。同時也可以讓我們得程式碼更加美觀。

1、高耦合低內聚。

高耦合:將功能聯繫緊密得部分放到一個容器元件內對外暴漏出index.js,目錄結構如下:

├── components
│   └── App
└── index.js

低內聚:當這個元件在呼叫頁面直接刪除時,不會觸發任何影響;減少無必要的重複渲染;減少重複渲染時影響得範圍。

2、展示元件與容器元件

展示元件 容器元件
專注於事物的展示 專注於事物如何運作
#可能包含展示和容器元件,並且一般會有DOM標籤和css樣式 可能包含展示和容器元件,且不會有DOM標籤和css樣式
#常常允許透過this.props.children傳遞 提供資料和行為給容器元件或展示元件
對第三方沒有任何依賴,例如store 或flux action 呼叫flux action 並且提供他們的回調給展示元件
不要指定資料如何載入和變化 作為資料來源,通常採用較高階的元件,而不是自己寫,例如React Redux的connect(), Relay的createContainer(), Flux Utils的Container.create()
很少有自己的狀態,即使有,也是自己的UI狀態
#

這裡重點說下this.props.children。透過this.props.children我們很容易讓我們得組件變的低內聚。在實際開發中往往會遇到用純元件寫得展示元件下還有要繼續跟跟資料打交道得容器元件。這裡就用this.props.children套上這些容器元件就可以了。然後被套得容器元件可以繼續依照上面得規則新建個資料夾暴漏出index.js這種寫法。
這種寫法得最大好處是你很快就能找到你寫得這個元件是在哪,是乾嘛得,影響了哪。

3、從頂部向下得單向資料流

當我們得設計滿足上面這些條件時,使用從頂部向下的單向資料流會讓我們在使用一些類似於redux這種得狀態管理工具時,影響的範圍更加可控,再透過shouldComponentUpdate來減少不必要的渲染。 (不過這麼寫確實挺麻煩的,但是react從v16.3開始使用新的生命週期函數getDerivedStateFromProps來強制開發者對這一步進行優化)

4、受控組件和非受控組件

有許多的web元件可以被使用者的互動發生改變,例如:元件無法從外部修改
2 .一個透過props來設定value值的元件只能透過外部控制來更新。

受控元件:

一個受控的應該有一個value屬性。渲染一個受控的元件會展示value屬性的值。
一個受控的元件不會維護它自己內部的狀態,元件的渲染單純的依賴props。也就是說,如果我們有一個透過props來設定value的元件,不管你如何輸入,它只會顯示props.value。換句話說,你的組件是唯讀的。
在處理一個受控元件的時候,應該始終傳一個value屬性進去,並且註冊一個onChange的回呼函數讓元件變得可變。

非受控元件:

一個沒有value屬性的就是一個非受控元件。透過渲染的元素,任意的使用者輸入都會被立即反映出來。非受控的只能透過OnChange函數來向上層通知自己被使用者輸入的變更。

# 混合元件:

同時維護props.value和state.value的值。 props.value在展示上有較高的優先權,state.value代表著元件真正的值。

5、使用高階元件(HOC)


簡單定義:一個接收react元件作為參數傳回另一個元件的函數。
可以做什麼:程式碼復用,程式碼模組化增刪改props

使用案例:比方說公司突然要給前端程式碼不同的點擊埋點,就可以使用hoc包一層,再不改動原來各處程式碼得同時進行了合理得改動。

6、增刪改查標準流程


增:填寫數據,驗證數據,插入數據,重新查詢數據列表。
刪:確認刪除,重新查詢資料清單。
查:查詢數據列表,分頁顯示

改:填寫數據,驗證數據,修改數據,重新查詢數據列表

其實設計組件時沒必要過早的組件化。我們可以先快速的寫出一個版本,然後再根據實際設計拆分以應對專案初期的需求快速變更。然後一點一點的按照設計模式去改變我們的項目,只要設計模式合理地拆分其實是一件很流暢、很自然的事情。

更多程式相關知識,請造訪:程式設計影片

! ! ###

以上是合理設計React元件,讓程式碼更美觀! !的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:csdn。如有侵權,請聯絡admin@php.cn刪除
幕後:什麼語言能力JavaScript?幕後:什麼語言能力JavaScript?Apr 28, 2025 am 12:01 AM

JavaScript在瀏覽器和Node.js環境中運行,依賴JavaScript引擎解析和執行代碼。 1)解析階段生成抽象語法樹(AST);2)編譯階段將AST轉換為字節碼或機器碼;3)執行階段執行編譯後的代碼。

Python和JavaScript的未來:趨勢和預測Python和JavaScript的未來:趨勢和預測Apr 27, 2025 am 12:21 AM

Python和JavaScript的未來趨勢包括:1.Python將鞏固在科學計算和AI領域的地位,2.JavaScript將推動Web技術發展,3.跨平台開發將成為熱門,4.性能優化將是重點。兩者都將繼續在各自領域擴展應用場景,並在性能上有更多突破。

Python vs. JavaScript:開發環境和工具Python vs. JavaScript:開發環境和工具Apr 26, 2025 am 12:09 AM

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

JavaScript是用C編寫的嗎?檢查證據JavaScript是用C編寫的嗎?檢查證據Apr 25, 2025 am 12:15 AM

是的,JavaScript的引擎核心是用C語言編寫的。 1)C語言提供了高效性能和底層控制,適合JavaScript引擎的開發。 2)以V8引擎為例,其核心用C 編寫,結合了C的效率和麵向對象特性。 3)JavaScript引擎的工作原理包括解析、編譯和執行,C語言在這些過程中發揮關鍵作用。

JavaScript的角色:使網絡交互和動態JavaScript的角色:使網絡交互和動態Apr 24, 2025 am 12:12 AM

JavaScript是現代網站的核心,因為它增強了網頁的交互性和動態性。 1)它允許在不刷新頁面的情況下改變內容,2)通過DOMAPI操作網頁,3)支持複雜的交互效果如動畫和拖放,4)優化性能和最佳實踐提高用戶體驗。

C和JavaScript:連接解釋C和JavaScript:連接解釋Apr 23, 2025 am 12:07 AM

C 和JavaScript通過WebAssembly實現互操作性。 1)C 代碼編譯成WebAssembly模塊,引入到JavaScript環境中,增強計算能力。 2)在遊戲開發中,C 處理物理引擎和圖形渲染,JavaScript負責遊戲邏輯和用戶界面。

從網站到應用程序:JavaScript的不同應用從網站到應用程序:JavaScript的不同應用Apr 22, 2025 am 12:02 AM

JavaScript在網站、移動應用、桌面應用和服務器端編程中均有廣泛應用。 1)在網站開發中,JavaScript與HTML、CSS一起操作DOM,實現動態效果,並支持如jQuery、React等框架。 2)通過ReactNative和Ionic,JavaScript用於開發跨平台移動應用。 3)Electron框架使JavaScript能構建桌面應用。 4)Node.js讓JavaScript在服務器端運行,支持高並發請求。

Python vs. JavaScript:比較用例和應用程序Python vs. JavaScript:比較用例和應用程序Apr 21, 2025 am 12:01 AM

Python更適合數據科學和自動化,JavaScript更適合前端和全棧開發。 1.Python在數據科學和機器學習中表現出色,使用NumPy、Pandas等庫進行數據處理和建模。 2.Python在自動化和腳本編寫方面簡潔高效。 3.JavaScript在前端開發中不可或缺,用於構建動態網頁和單頁面應用。 4.JavaScript通過Node.js在後端開發中發揮作用,支持全棧開發。

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脫衣器

Video Face Swap

Video Face Swap

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

熱工具

PhpStorm Mac 版本

PhpStorm Mac 版本

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

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3 Mac版

SublimeText3 Mac版

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

MantisBT

MantisBT

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

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具