本篇文章主要介紹了react redux入門示例,如今分享給你們,也給你們作個參考。若有不足之處,歡迎批評指正。css
環境準備 爲了方便,這裏使用create-react-app搭建react環境前端
create-react-app mydemo
彈出配置react
若是須要自定義react的配置,須要運行下面的命令把配置文件彈出來。npm
npm run eject
安裝reduxredux
npm i redux --save
簡單理解app
redux簡單用法就是經過它的store來訂閱和發佈信息。dom
經過subscribe來訂閱action,經過dispatch來觸發action。reducer中定義來各個action要作的事情。異步
demo代碼ide
reducer定義函數
const Add = 'addGirl'``, Remove = "removeGirl"``; export function reducer(state = 0, action) { switch (action.type) { case Add: return state + 1; case Remove: return state - 1; default``: return 10; }//歡迎加入前端全棧開發交流圈一塊兒學習交流:864305860 } //action creator,把action封裝成一個方法,這樣用的時候不用每次定義,避免出錯 export function addCreator() { return { type: Add }; } export function removeCreator() { return { type: Remove }; } export function addAsync() { return (dispatch, getState) => { setTimeout(``function () { dispatch(addCreator()); }, 1000);//歡迎加入前端全棧開發交流圈一塊兒學習交流:864305860 }//面向1-3年前端人員 }//幫助突破技術瓶頸,提高思惟能力
入口文件index.js
import React from 'react'``; import ReactDOM from 'react-dom'``; import './index.css'``; import App from './App'``; import registerServiceWorker from './registerServiceWorker'``; import { createStore } from 'redux'``; import thunk from 'redux-thunk'``; import { reducer,addCreator,removeCreaator } from './index.redux'``; import { Provider } from 'react-redux' const store = createStore(reducer); function render() { ReactDOM.render( <App store={store} addCreator={addCreator} removeCreator={removeCreator} />, document.getElementById(``'root'``) ); } //封裝成方法,方便下面的store的訂閱調用 render(); //每當dispatch時,訂閱的函數就會執行 store.subscribe(render); registerServiceWorker();
App.js
import React, { Component } from 'react'``; import './App.css'``; class App extends Component { render() { var store=``this``.props.store; var num=store.getState(); return ( <div className=``"App"``> <h1>如今有機關槍{``this``.props.num}把。</h1> <button onClick={() => { store.dispatch(``this``.props.addCreator()) }}>add</button> <button onClick={() => { store.dispatch(``this``.props.removeCreator()) }}>remove</button> </div >//歡迎加入前端全棧開發交流圈一塊兒學習交流:864305860 ); } } export default App;
經過store的dispatch來觸發action,index.js中訂閱的事件就會執行。
redux的異步執行
redux中若是須要執行異步操做,須要安裝react-thunk插件
npm i react-thunk --save
同時須要redux插件的applyMiddleware
關鍵代碼
設置其實很簡單,建立store時,把thunk傳遞給它就好了。
import thunk from 'redux-thunk'``; const store = createStore(reducer, applyMiddleware(thunk));
在app.js中增長一個觸發異步操做的按鈕,reducer中已經定義了一個異步的方法。
export function addAsync() { return (dispatch, getState) => { setTimeout(``function () { dispatch(addCreator()); }, 1000);//歡迎加入前端全棧開發交流圈一塊兒學習交流:864305860 } }
異步調用方法會返回一個有兩個參數的方法,兩個參數都是函數,第一個是dispatch函數,第二個是getState函數。 dispatch觸發action,getState獲取state的值。
在app.js中增長代碼
<button onClick={() => { store.dispatch(``this``.props.addAsync()) }}>addAsync</button>
結語
感謝您的觀看,若有不足之處,歡迎批評指正。