小程序使用taro时集成redux-saga

本文介绍了在使用Taro开发小程序的过程中,如何将原本的redux-thunk替换为redux-saga来管理异步操作。详细步骤包括初始化小程序,修改store.js以引入redux-saga,更新app.js,以及配置saga、reducers、actions和请求常量文件。
摘要由CSDN通过智能技术生成

使用taro开发小程序时,初始化小程序

taro init myApp

选择redux组件。

可以看到redux中, store.js里使用的是redux-thunk管理异步

import {
    createStore, applyMiddleware, compose } from 'redux'
import thunkMiddleware from 'redux-thunk'
import rootReducer from '../reducers'

const composeEnhancers =
  typeof window === 'object' &&
  window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ ?   
    window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__({
   
      // Specify extension’s options like name, actionsBlacklist, actionsCreators, serialize...
    }) : compose

const middlewares = [
  thunkMiddleware
]

if (process.env.NODE_ENV === 'development') {
   
  middlewares.push(require('redux-logger').createLogger())
}

const enhancer = composeEnhancers(
  applyMiddleware(...middlewares),
  // other store enhancers if any
)

export default function configStore () {
   
  const store = createStore(rootReducer, enhancer)
  return store
}

就将以上修改一下换成redux-saga

import {
    createStore, applyMiddleware, compose } from 'redux';
import createSagaMiddleware, {
    END } from 'redux-saga';
import rootReducer from '../reducers/index';


const composeEnhancers =
	typeof window === 'object' &&
		window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ ?
		window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__({
   
			// Specify extension’s options like name, actionsBlacklist, actionsCreators, serialize...
		}) : compose


export default function configStore() {
   

	const sagamiddleware = createSagaMiddleware();
	const middlewares = [
		sagamiddleware
	]

	if (process.env.NODE_ENV === 'development') {
   
		middlewares.push(require('redux-logger').createLogger());
	}

	const store = createStore(rootReducer, composeEnhancers(applyMiddleware(...middlewares)));
	store.runSaga = sagamiddleware.run
	store.close = 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值