react redux入門示例
環(huán)境準備
為了方便,這里使用create-react-app搭建react環(huán)境
create-react-app mydemo
彈出配置
如果需要自定義react的配置,需要運行下面的命令把配置文件彈出來。
npm run eject
安裝redux
npm i redux --save
簡單理解
redux簡單用法就是通過它的store來訂閱和發(fā)布信息。
通過subscribe來訂閱action,通過dispatch來觸發(fā)action。reducer中定義來各個action要做的事情。
demo代碼
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; } } //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); } }
入口文件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的訂閱調(diào)用 render(); //每當dispatch時,訂閱的函數(shù)就會執(zhí)行 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>現(xiàn)在有機關(guān)槍{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來觸發(fā)action,index.js中訂閱的事件就會執(zhí)行。
redux的異步執(zhí)行
redux中如果需要執(zhí)行異步操作,需要安裝react-thunk插件
npm i react-thunk --save
同時需要redux插件的applyMiddleware
關(guān)鍵代碼
設置其實很簡單,創(chuàng)建store時,把thunk傳遞給它就行了。
import thunk from 'redux-thunk'; const store = createStore(reducer, applyMiddleware(thunk));
在app.js中增加一個觸發(fā)異步操作的按鈕,reducer中已經(jīng)定義了一個異步的方法。
export function addAsync() { return (dispatch, getState) => { setTimeout(function () { dispatch(addCreator()); }, 1000); } }
異步調(diào)用方法會返回一個有兩個參數(shù)的方法,兩個參數(shù)都是函數(shù),第一個是dispatch函數(shù),第二個是getState函數(shù)。
dispatch觸發(fā)action,getState獲取state的值。
在app.js中增加代碼
<button onClick={() => { store.dispatch(this.props.addAsync()) }}>addAsync</button>
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
ReactNative踩坑之配置調(diào)試端口的解決方法
本篇文章主要介紹了ReactNative踩坑之配置調(diào)試端口的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07react?hooks?計數(shù)器實現(xiàn)代碼
這篇文章主要介紹了react?hooks計數(shù)器實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-08-08React Native可復用 UI分離布局組件和狀態(tài)組件技巧
這篇文章主要為大家介紹了React Native可復用 UI分離布局組件和狀態(tài)組件使用技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-09-09react事件對象無法獲取offsetLeft,offsetTop,X,Y等元素問題及解決
這篇文章主要介紹了react事件對象無法獲取offsetLeft,offsetTop,X,Y等元素問題及解決方案,具有很好的參考價值,希望對大家有所幫助。2022-08-08