首頁 web前端 js教程 使用react、redux、react-redux

使用react、redux、react-redux

Jun 08, 2018 pm 03:03 PM
react redux 關係

這次帶給大家使用react、redux、react-redux,使用react、redux、react-redux的注意事項有哪些,以下就是實戰案例,一起來看一下。

本文介紹了react、redux、react-redux之間的關係,分享給大家,也給自己留個筆記,具體如下:

React

一些小型項目,只使用React 完全夠用了,資料管理使用props、state即可,那什麼時候需要引進Redux呢?當渲染一個元件的資料是透過props從父元件中取得時,通常情況下是A --> B,但隨著業務複雜度的增加,有可能是這樣的:A --> B -- > C --> D --> E,E需要的資料需要從A那裡透過props傳遞過來,以及對應的E --> A逆向傳遞callback。組件BCD是不需要這些資料的,但是又必須經由它們來傳遞,這確實有點不爽,而且傳遞的props以及callback對BCD組件的複用也會造成影響。或是兄弟組件之間想要分享某些數據,也不是很方便傳遞、取得等。諸如此類的情況,就有必要引進Redux了。

其實A --> B --> C --> D --> E 這種情況,React不使用props層層傳遞也是能拿到資料的,使用Context即可。後面要講到的react-redux就是透過Context讓各個子元件拿到store裡的資料的。

Redux

其實我們只是想找個地方存放一些共享資料而已,大家都可以取得到,也都可以進行修改,僅此而已。那放在一個全部變數裡面行不行?行,當然行,但是太不優雅,也不安全,因為是全域變數嘛,誰都能存取、誰都能修改,有可能一不小心被哪個小夥伴覆蓋了也說不定。那全域變數不行就用私有變數唄,私有變數、無法輕易修改,是不是立刻就想到閉包了...

現在要寫這樣一個函數,其滿足:

  1. 存放一個資料物件

  2. 外界能存取這個資料

  3. #外界也能修改這個資料

  4. 當資料有變化的時候,通知訂閱者

function createStore(reducer, initialState) {
 // currentState就是那个数据
 let currentState = initialState;
 let listener = () => {};
 function getState() {
 return currentState;
 }
 function dispatch(action) {
 currentState = reducer(currentState, action); // 更新数据
 listener(); // 执行订阅函数
 return action;
 }
 function subscribe(newListener) {
 listener = newListener;
 // 取消订阅函数
 return function unsubscribe() {
  listener = () => {};
 };
 }
 return {
 getState,
 dispatch,
 subscribe
 };
}
const store = createStore(reducer);
store.getState(); // 获取数据
store.dispatch({type: 'ADD_TODO'}); // 更新数据
store.subscribe(() => {/* update UI */}); // 注册订阅函数
登入後複製

更新資料執行的步驟:

  1. What:想做什麼--- dispatch(action)

  2. How:怎麼幹,幹的結果--- reducer(oldState, action) => newState

  3. #Then?:重新執行訂閱函數(例如重新渲染UI等)

這樣就實作了一個store,提供一個資料儲存中心,可以供外部存取、修改等,這就是Redux的主要思想。所以,Redux確實和React沒有什麼本質關係,Redux可以結合其他函式庫正常使用。只不過Redux這種資料管理方式,跟React的資料驅動視圖概念很合拍,它兩個結合在一起,開發非常便利。

現在既然有了一個安全的地方可以存取數據,要怎麼結合到React裡面呢?我們可以在應用初始化的時候,創建一個window.store = createStore(reducer),然後在需要的地方通過store.getState()去獲取數據,通過store.dispatch去更新數據,通過store.subscribe去訂閱數據變化然後進行setState...如果很多地方都這樣做一遍,實在是不堪其重,而且,還是沒有避免掉全域變數的不優雅。

React-Redux

由於全域變數有諸多的缺點,那就換個思路,把store直接整合到React應用的頂層props裡面,只要各個子元件能存取到頂層props就行了,像這樣:

<TopWrapComponent store={store}>
 <App />
</TopWrapComponent>,
登入後複製

React剛好提供了這麼一個鉤子,Context,用法很簡單,看一下官方demo就明了。現在各個子元件已經能夠輕易存取到store了,接下來就是子元件把store裡用到的資料取出、修改、以及訂閱更新UI等。每個子組件都需要這樣做一遍,顯然,肯定有更方便的方法:高階組件。透過高階元件把store.getState()、store.dispatch、store.subscribe封裝起來,子元件對store就無感知了,子元件正常使用props取得資料以及正常使用callback觸發回調,相當於沒有store存在一樣。

下面是這個高階元件的大致實作:

function connect(mapStateToProps, mapDispatchToProps) {
 return function(WrappedComponent) {
 class Connect extends React.Component {
  componentDidMount() {
  // 组件加载完成后订阅store变化,如果store有变化则更新UI
  this.unsubscribe = this.context.store.subscribe(this.handleStoreChange.bind(this));
  }
  componentWillUnmount() {
  // 组件销毁后,取消订阅事件
  this.unsubscribe();
  }
  handleStoreChange() {
  // 更新UI
  this.forceUpdate();
  }
  render() {
  return (
   <WrappedComponent
   {...this.props}
   {...mapStateToProps(this.context.store.getState())} // 参数是store里面的数据
   {...mapDispatchToProps(this.context.store.dispatch)} // 参数是store.dispatch
   />
  );
  }
 }
 Connect.contextTypes = {
  store: PropTypes.object
 };
 return Connect;
 };
}
登入後複製

使用connect的時候,我們知道要寫一些樣板化的程式碼,例如mapStateToProps、mapDispatchToProps這兩個函數:

const mapStateToProps = state => {
 return {
 count: state.count
 };
};
const mapDispatchToProps = dispatch => {
 return {
 dispatch
 };
};
export default connect(mapStateToProps, mapDispatchToProps)(Child);
// 上述代码执行之后,可以看到connect函数里面的
 <WrappedComponent
 {...this.props}
 {...mapStateToProps(this.context.store.getState())}
 {...mapDispatchToProps(this.context.store.dispatch)}
 />
// 就变成了
 <WrappedComponent
 {...this.props}
 {count: store.getState().count}
 {dispatch: store.dispatch}
 />
// 这样,子组件Child的props里面就多了count和dispatch两个属性
// count可以用来渲染UI,dispatch可以用来触发回调
登入後複製

So,这样就OK了?OK了。 通过一个闭包生成一个数据中心store,然后把这个store绑定到React的顶层props里面,子组件通过HOC建立与顶层props.store的联系,进而获取数据、修改数据、更新UI。 这里主要讲了一下三者怎么窜在一起的,如果想了解更高级的功能,比如redux中间件、reducer拆分、connect的其他参数等,可以去看一下对应的源码。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

怎样做出鼠标点击处心形图案漂浮

JS操作JSON数组去重

以上是使用react、redux、react-redux的詳細內容。更多資訊請關注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)

如何利用React和RabbitMQ建立可靠的訊息應用 如何利用React和RabbitMQ建立可靠的訊息應用 Sep 28, 2023 pm 08:24 PM

如何利用React和RabbitMQ建立可靠的訊息傳遞應用程式引言:現代化的應用程式需要支援可靠的訊息傳遞,以實現即時更新和資料同步等功能。 React是一種流行的JavaScript庫,用於建立使用者介面,而RabbitMQ是一種可靠的訊息傳遞中間件。本文將介紹如何結合React和RabbitMQ建立可靠的訊息傳遞應用,並提供具體的程式碼範例。 RabbitMQ概述:

React Router使用指南:如何實現前端路由控制 React Router使用指南:如何實現前端路由控制 Sep 29, 2023 pm 05:45 PM

ReactRouter使用指南:如何實現前端路由控制隨著單頁應用的流行,前端路由成為了一個不可忽視的重要部分。 ReactRouter作為React生態系統中最受歡迎的路由庫,提供了豐富的功能和易用的API,使得前端路由的實作變得非常簡單和靈活。本文將介紹ReactRouter的使用方法,並提供一些具體的程式碼範例。安裝ReactRouter首先,我們需要

PHP、Vue和React:如何選擇最適合的前端框架? PHP、Vue和React:如何選擇最適合的前端框架? Mar 15, 2024 pm 05:48 PM

PHP、Vue和React:如何選擇最適合的前端框架?隨著互聯網技術的不斷發展,前端框架在Web開發中起著至關重要的作用。 PHP、Vue和React作為三種代表性的前端框架,每一種都具有其獨特的特徵和優勢。在選擇使用哪種前端框架時,開發人員需要根據專案需求、團隊技能和個人偏好做出明智的決策。本文將透過比較PHP、Vue和React這三種前端框架的特徵和使

Java框架與前端React框架的整合 Java框架與前端React框架的整合 Jun 01, 2024 pm 03:16 PM

Java框架與React框架的整合:步驟:設定後端Java框架。建立專案結構。配置建置工具。建立React應用程式。編寫RESTAPI端點。配置通訊機制。實戰案例(SpringBoot+React):Java程式碼:定義RESTfulAPI控制器。 React程式碼:取得並顯示API回傳的資料。

如何利用React開發一個響應式的後台管理系統 如何利用React開發一個響應式的後台管理系統 Sep 28, 2023 pm 04:55 PM

如何利用React開發一個響應式的後台管理系統隨著互聯網的快速發展,越來越多的企業和組織需要一個高效、靈活、易於管理的後台管理系統來處理日常的操作事務。 React作為目前最受歡迎的JavaScript庫之一,提供了一種簡潔、高效和可維護的方式來建立使用者介面。本文將介紹如何利用React開發一個響應式的後台管理系統,並給出具體的程式碼範例。建立React專案首先

vue.js vs.反應:特定於項目的考慮因素 vue.js vs.反應:特定於項目的考慮因素 Apr 09, 2025 am 12:01 AM

Vue.js適合中小型項目和快速迭代,React適用於大型複雜應用。 1)Vue.js易於上手,適用於團隊經驗不足或項目規模較小的情況。 2)React的生態系統更豐富,適合有高性能需求和復雜功能需求的項目。

react有哪些閉包 react有哪些閉包 Oct 27, 2023 pm 03:11 PM

react有事件處理函數、useEffect和useCallback、高階元件等等閉包。詳細介紹:1、事件處理函數閉包:在React中,當我們在元件中定義事件處理函數時,函數會形成一個閉包,可以存取元件作用域內的狀態和屬性。這樣可以在事件處理函數中使用元件的狀態和屬性,實現互動邏輯;2、useEffect和useCallback中的閉包等等。

React在HTML中的作用:增強用戶體驗 React在HTML中的作用:增強用戶體驗 Apr 09, 2025 am 12:11 AM

React通過JSX與HTML結合,提升用戶體驗。 1)JSX嵌入HTML,使開發更直觀。 2)虛擬DOM機制優化性能,減少DOM操作。 3)組件化管理UI,提高可維護性。 4)狀態管理和事件處理增強交互性。

See all articles