目錄
1、高耦合低內聚。
2、展示元件與容器元件
3、從頂部向下得單向資料流
4、受控組件和非受控組件
受控元件:
非受控元件:
首頁 web前端 js教程 合理設計React元件,讓程式碼更美觀! !

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

Feb 13, 2021 am 09:10 AM
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中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱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

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

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

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

前端熱敏紙小票打印遇到亂碼問題怎麼辦? 前端熱敏紙小票打印遇到亂碼問題怎麼辦? Apr 04, 2025 pm 02:42 PM

前端熱敏紙小票打印的常見問題與解決方案在前端開發中,小票打印是一個常見的需求。然而,很多開發者在實...

誰得到更多的Python或JavaScript? 誰得到更多的Python或JavaScript? Apr 04, 2025 am 12:09 AM

Python和JavaScript開發者的薪資沒有絕對的高低,具體取決於技能和行業需求。 1.Python在數據科學和機器學習領域可能薪資更高。 2.JavaScript在前端和全棧開發中需求大,薪資也可觀。 3.影響因素包括經驗、地理位置、公司規模和特定技能。

神秘的JavaScript:它的作用以及為什麼重要 神秘的JavaScript:它的作用以及為什麼重要 Apr 09, 2025 am 12:07 AM

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

如何使用JavaScript將具有相同ID的數組元素合併到一個對像中? 如何使用JavaScript將具有相同ID的數組元素合併到一個對像中? Apr 04, 2025 pm 05:09 PM

如何在JavaScript中將具有相同ID的數組元素合併到一個對像中?在處理數據時,我們常常會遇到需要將具有相同ID�...

JavaScript難以學習嗎? JavaScript難以學習嗎? Apr 03, 2025 am 12:20 AM

學習JavaScript不難,但有挑戰。 1)理解基礎概念如變量、數據類型、函數等。 2)掌握異步編程,通過事件循環實現。 3)使用DOM操作和Promise處理異步請求。 4)避免常見錯誤,使用調試技巧。 5)優化性能,遵循最佳實踐。

如何實現視差滾動和元素動畫效果,像資生堂官網那樣?
或者:
怎樣才能像資生堂官網一樣,實現頁面滾動伴隨的動畫效果? 如何實現視差滾動和元素動畫效果,像資生堂官網那樣? 或者: 怎樣才能像資生堂官網一樣,實現頁面滾動伴隨的動畫效果? Apr 04, 2025 pm 05:36 PM

實現視差滾動和元素動畫效果的探討本文將探討如何實現類似資生堂官網(https://www.shiseido.co.jp/sb/wonderland/)中�...

console.log輸出結果差異:兩次調用為何不同? console.log輸出結果差異:兩次調用為何不同? Apr 04, 2025 pm 05:12 PM

深入探討console.log輸出差異的根源本文將分析一段代碼中console.log函數輸出結果的差異,並解釋其背後的原因。 �...

JavaScript的演變:當前的趨勢和未來前景 JavaScript的演變:當前的趨勢和未來前景 Apr 10, 2025 am 09:33 AM

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

See all articles