亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

React總結篇之四_模塊化React和Redux應用

發布時間:2020-03-30 20:29:40 來源:網絡 閱讀:829 作者:cylcyl647308 欄目:web開發

創建一個復雜一點的應用應該如何做:

  • 模塊化應用的要點
  • 代碼文件的組織方式
  • 狀態數的設計
  • 開發輔助工具

一、模塊化應用的要點
1.構建一個應用的基礎要做如下3件事情:

  • 代碼文件的組織結構
  • 確定模塊的邊界
  • store的狀態樹設計
  1. 代碼文件的組織方式:
    按功能組織
    Redux應用適用于按功能組織劃分,即把完成同一應用功能的代碼放在一個目錄下,一個應用功能包含多個角色的代碼。在Redux中,不同的角色就是reducer、actions和視圖,而應用功能對應的就是用戶界面上的交互模塊。
    拿Todo應用為例子,這個應用的兩個基本功能就是TodoList和Filter,所以代碼就這樣組織,文件目錄列表如下:
    React總結篇之四_模塊化React和Redux應用
    每個基本功能對應的其實就是一個功能模塊,每個功能模塊對應一個目錄,每個目錄下包含同樣名字的角色文件。

    • actionTypes.js定義action類型;
    • actions.js定義action構造函數,決定了這個功能模塊可以接受的動作;
    • reducer.js定義這個功能模塊如何響應actions.js中定義的動作;
    • views目錄,包含這個功能模塊中所有的React組件,包括傻瓜組件和容器組件;
    • index.js這個文件把所有的角色導入,然后統一導出
      在這種組織方式下,當你要修改某個功能模塊的代碼的時候,只要關注對應的目錄就行了,所有需要修改的代碼文件都能在這個目錄下找到。
  2. 模塊接口
    每個功能模塊下都有一個index.js文件,這個文件就是我們的模塊接口。
    舉例如下:
    import * as actions from './actions.js'
    import reducer from './reducer.js'
    import view from './views/container.js'
    export {actions,reducer,view}
    如果filter中的組件想要使用todoList中的功能,應該導入todoList這個目錄。因為導入這個目錄的時候,默認導入的就是這個目錄下的index.js文件,就是這個模塊想要公開出來的接口。

4.狀態樹的設計
狀態樹的設計建議遵循以下幾個原則:

  • 一個模塊控制一個狀態節點
  • 避免冗余數據
  • 樹形結構扁平

4.1 一個狀態節點只屬于一個模塊
在Redux應用中,store上的每一個state都只能通過reducer來更改,而我們每個模塊都有機會導出一個自己的reducer,這個導出的reducer只能最多更改Redux的狀態樹上一個節點下的數據,因為reducer之間對狀態樹上的修改權是互斥的,不能讓兩個reducer都可以修改同一個狀態樹上的節點。比如,如果A模塊的reducer負責修改狀態樹a字段下的數據,那么另一個模塊B的reducer就不可能有機會修改a字段下的數據。這里指的是‘修改權’,不是‘讀取權’(讀取權對任何模塊都是開放的)。

4.2 避免冗余數據
在Redux的Store中,一定要避免數據的冗余,因為這可能會導致數據不一致的問題。

4.3 樹形結構扁平
在設計Redux Store的狀態樹時,要盡量保持樹形結構的扁平(樹形結構不要深)。

4.4 不使用ref

4.5 開發輔助工具

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

新平| 杨浦区| 郯城县| 巫山县| 若尔盖县| 上蔡县| 新绛县| 楚雄市| 桃江县| 疏附县| 保靖县| 环江| 湖口县| 侯马市| 青岛市| 易门县| 三河市| 平潭县| 四会市| 宜良县| 西宁市| 皮山县| 彭水| 卓尼县| 买车| 荃湾区| 青河县| 清新县| 湖州市| 青阳县| 江都市| 时尚| 吉木乃县| 东莞市| 建平县| 申扎县| 三亚市| 邵阳市| 白沙| 琼海市| 青河县|