国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

react redux入門示例

2019-11-19 14:00:01
字體:
供稿:網(wǎng)友

環(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)鍵代碼

設(shè)置其實很簡單,創(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)容,希望對大家的學(xué)習有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 和静县| 东海县| 新昌县| 乐陵市| 吴川市| 长海县| 达日县| 平阳县| 安福县| 壶关县| 麦盖提县| 兰州市| 微博| 北票市| 锡林浩特市| 荣昌县| 界首市| 延吉市| 南川市| 建昌县| 深水埗区| 泸西县| 广州市| 大足县| 北宁市| 宁南县| 连山| 大余县| 二连浩特市| 梨树县| 新乡市| 湾仔区| 长汀县| 五台县| 鹤壁市| 平远县| 兴义市| 嘉善县| 普兰县| 青阳县| 衢州市|