爲了方便,這裏使用create-react-app
搭建react環境css
create-react-app mydemo
若是須要自定義react的配置,須要運行下面的命令把配置文件彈出來。react
npm run eject
npm i redux --save
redux簡單用法就是經過它的store
來訂閱和發佈信息。
經過subscribe
來訂閱action
,經過dispatch
來觸發action
。reducer
中定義來各個action要作的事情。npm
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; } } //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); } }
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();
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 > ); } } export default App;
經過store
的dispatch
來觸發action
,index.js
中訂閱的事件就會執行。redux
redux中若是須要執行異步操做,須要安裝react-thunk
插件app
npm i react-thunk --save
同時須要redux插件的applyMiddleware
dom
設置其實很簡單,建立store時,把thunk傳遞給它就好了。異步
import thunk from 'redux-thunk'; const store = createStore(reducer, applyMiddleware(thunk));
在app.js中增長一個觸發異步操做的按鈕,reducer中已經定義了一個異步的方法。ide
export function addAsync() { return (dispatch, getState) => { setTimeout(function () { dispatch(addCreator()); }, 1000); } }
異步調用方法會返回一個有兩個參數的方法,兩個參數都是函數,第一個是dispatch函數,第二個是getState函數。
dispatch觸發action,getState獲取state的值。函數
在app.js中增長代碼this
<button onClick={() => { store.dispatch(this.props.addAsync()) }}>addAsync</button>