3) redux-thunk处理异步操作

 redux基本概念:redux初体验(问题记录)_FF_XM的博客-CSDN博客

react-redux封装redux: react-redux抽离redux_FF_XM的博客-CSDN博客

为什么用redux-thunk?

redux无法进行异步操作,需要借助中间件(redux-thunk)来完成异步。

下载包 npm install --save  redux-thunk

接上篇react-redux的使用

// 引入应用中间件函数applyMiddleware
import { configureStore, applyMiddleware } from '@reduxjs/toolkit'
import thunk from "redux-thunk";

import { counter } from './reducers'

// 根据counter函数创建store对象
const store = configureStore(
  { reducer: counter },
  // 异步处理中间件
  applyMiddleware(thunk)
)

export default store
// action.js
import { INCREMENT, DECREMENT } from "./action-types";
export const increment = (number) => ({ type: INCREMENT, data: number })
export const decrement = (number) => ({ type: DECREMENT, data: number })
// 新增异步方法
export const incrementAsync = (number) => {
  return dispatchEvent => (
    setTimeout(() => {
      dispatchEvent(increment(number))
    }, 1000)
  )
}
// app.js
import { connect } from "react-redux";
// 引入action内的方法
import { increment, decrement, incrementAsync } from "../redux/actions";
// 引入容器组件
import counter from "../components/counter";

export default connect(
  (state) => {
    // 将state状态传给counter组件
    return { count: state };
  },
  // 将异步方法incrementAsync传给counter组件
  { increment, decrement, incrementAsync }
)(counter);

 counter组件内引入异步方法

完工~

redux-devtool插件使用

插件链接:百度网盘 请输入提取码 提取码:kdmc

拖入谷歌扩展程序内

下载工具依赖包

npm install --save-dev redux-devtools-extension

// store.js
import { configureStore, applyMiddleware } from '@reduxjs/toolkit'
import thunk from "redux-thunk";
// redux-devtool引入插件
import { composeWithDevTools } from "redux-devtools-extension";

import { counter } from './reducers'

// 根据counter函数创建store对象
const store = configureStore(
  { reducer: counter },
  // 处理中间件
  composeWithDevTools(applyMiddleware(thunk))
)

export default store

重启项目后,即可成功

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值