react redux入门示例
环境准备
为了方便,这里使用create-react-app搭建react环境
create-react-appmydemo
弹出配置
如果需要自定义react的配置,需要运行下面的命令把配置文件弹出来。
npmruneject
安装redux
npmiredux--save
简单理解
redux简单用法就是通过它的store来订阅和发布信息。
通过subscribe来订阅action,通过dispatch来触发action。reducer中定义来各个action要做的事情。
demo代码
reducer定义
constAdd='addGirl',Remove="removeGirl"; exportfunctionreducer(state=0,action){ switch(action.type){ caseAdd: returnstate+1; caseRemove: returnstate-1; default: return10; } } //actioncreator,把action封装成一个方法,这样用的时候不用每次定义,避免出错 exportfunctionaddCreator(){ return{type:Add}; } exportfunctionremoveCreator(){ return{type:Remove}; } exportfunctionaddAsync(){ return(dispatch,getState)=>{ setTimeout(function(){ dispatch(addCreator()); },1000); } }
入口文件index.js
importReactfrom'react'; importReactDOMfrom'react-dom'; import'./index.css'; importAppfrom'./App'; importregisterServiceWorkerfrom'./registerServiceWorker'; import{createStore}from'redux'; importthunkfrom'redux-thunk'; import{reducer,addCreator,removeCreaator}from'./index.redux'; import{Provider}from'react-redux' conststore=createStore(reducer); functionrender(){ ReactDOM.render(, document.getElementById('root') ); } //封装成方法,方便下面的store的订阅调用 render(); //每当dispatch时,订阅的函数就会执行 store.subscribe(render); registerServiceWorker();
App.js
importReact,{Component}from'react'; import'./App.css'; classAppextendsComponent{ render(){ varstore=this.props.store; varnum=store.getState(); return(现在有机关枪{this.props.num}把。
{store.dispatch(this.props.addCreator())}}>add {store.dispatch(this.props.removeCreator())}}>remove
通过store的dispatch来触发action,index.js中订阅的事件就会执行。
redux的异步执行
redux中如果需要执行异步操作,需要安装react-thunk插件
npmireact-thunk--save
同时需要redux插件的applyMiddleware
关键代码
设置其实很简单,创建store时,把thunk传递给它就行了。
importthunkfrom'redux-thunk'; conststore=createStore(reducer,applyMiddleware(thunk));
在app.js中增加一个触发异步操作的按钮,reducer中已经定义了一个异步的方法。
exportfunctionaddAsync(){ return(dispatch,getState)=>{ setTimeout(function(){ dispatch(addCreator()); },1000); } }
异步调用方法会返回一个有两个参数的方法,两个参数都是函数,第一个是dispatch函数,第二个是getState函数。
dispatch触发action,getState获取state的值。
在app.js中增加代码
{store.dispatch(this.props.addAsync())}}>addAsync
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。