为了方便,这里使用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>