首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

React saga_react获取子组件ref

如何处理副作用操作redux中选择发出action,到reducer处理函数之间使用中间件处理副作用。...action不易维护的原因: action的形式不统一 就是异步操作太为分散,分散了各个action中 2.redux-saga写一个hellosaga 跟redux-thunk,redux-saga...是控制执行的generator,redux-saga中action是原始的js对象,把所有的异步副作用操作放在了saga函数里面。...和调用redux的其他中间件一样,如果想使用redux-saga中间件,那么只要在applyMiddleware中调用一个createSagaMiddleware的实例。...3.redux-saga的使用技术细节 redux-saga除了上述的action统一、可以集中处理异步操作等优点外,redux-saga中使用声明式的Effect以及提供了更加细腻的控制流。

4.5K30

高频React面试题及详解

当然mobx和redux也并不一定是非此即彼的关系,你也可以项目中用redux作为全局状态管理,用mobx作为组件局部状态管理器来用. redux中如何进行异步操作?...功能孱弱: 有一些实际开发中常用的功能需要自己进行封装 redux-saga优点: 异步解耦: 异步操作被被转移到单独 saga.js 中,不再是掺杂 action.js 或 component.js...灵活: redux-saga可以将多个Saga可以串行/并行组合起来,形成一个非常实用的异步flow 易测试,提供了各种case的测试方案,包括mock task,分支覆盖等等 redux-saga缺陷...缺陷: 学习成本奇高: 如果你不会rxjs,则需要额外学习两个复杂的库 社区一般: redux-observable的下载量只有redux-saga的1/5,社区也不够活跃,复杂异步流中间件这个层面redux-saga...仍处于领导地位 关于redux-sagaredux- observable的详细比较可见此链接

2.4K40
您找到你想要的搜索结果了吗?
是的
没有找到

redux-saga

API形式提供,提供各种语义的用来生成Effect的工具函数,例如把dispatch action包装成put、把方法调用包装成call/apply Effect -> 业务操作 执行时内部进行转换...,例如把[Effect1, Effect2]转换为并行调用 类似于装箱(把业务操作用Effect包起来)拆箱(执行Effect里的业务操作),此外,完整的redux-saga还要实现: 作为middleware...常用的Effect creator如下: 阻塞型方法调用:call/apply 详见Declarative Effects 非阻塞型方法调用:fork/spawn 详见redux-saga’s fork...术语Saga指的是一系列操作的集合,是个运行时的抽象概念 redux-saga里的Saga形式上是generator,用来描述一组操作,而generator是个具体的静态概念 P.S.redux-saga...里所说的Saga大多数情况下指的都是generator形式的一组操作,而不是指redux-saga自身。

1.9K41

深入理解 redux 数据流和异步过程管理

没有,这段逻辑依然是组件里写,只不过移到了 dispatch 里,也没有提供多个异步过程的管理机制。 解决这个问题,需要用 redux-sagaredux-observable 中间件。...redux saga 的异步过程管理就是这样的:先把 action 透传给 store,然后判断 action 是否是被 taker 监听的,如果是,则调用对应的 worker saga 进行处理。...redux saga redux 的 action 流程之外,加了一条监听 action 的异步处理的流程。 其实整个流程还是比较容易理解的。... redux-saga 里面,控制 worker saga 执行的程序叫做 task。...所以做特别复杂的异步流程处理的时候,redux-observable 能够利用 rxjs 的操作符的优势会更明显。

2.4K10

react项目架构之路初探

redux-saga 通过创建 Sagas 将所有的异步操作逻辑收集一个地方集中处理,可以用来代替 redux-thunk 中间件。...Sagas 可以被看作是在后台运行的进程,Sagas 监听发起的action,然后决定基于这个 action来做什么 redux-saga 的世界里,所有的任务都通用 yield Effects 来完成...,thunks 是action被创建时调用,而 Sagas只会在应用启动时调用 redux-thunk中间件可以让action创建函数先不返回一个action对象,而是返回一个函数,函数传递两个参数...(dispatch,getState),函数体内进行业务逻辑的封装 redux-thunk的缺点: action的形式不统一 ,异步操作太分散,分散了各个action中 redux-saga本质是一个可以自执行的...集中了所有的异步操作, 可以实现非阻塞异步调用,也可以使用非阻塞调用下的事件监听 阻塞与非阻塞的概念 异步操作的流程可以人为手动控制流程 **seamless-immutable ** 关于immutable

2.4K10

前端实现异步的几种方式_redux是什么

3.什么是redux-sagaredux-saga是一个Redux中间件,用来帮你管理程序的副作用。或者更直接一点,主要是用来处理异步action。...上一篇我们介绍过Redux的中间件,说白了就是action被传递到reducer之前新进行了一次拦截,然后启动异步任务,等异步任务执行完成后再发送一个新的action,调用reducer修改状态数据。...然后我们看下workerSaga,可以看到并不是直接调用异步函数或者派发action,而是通过call()以及put()这样的函数。这就是redux-saga中最为重要的一个概念:Effect。...因此,相比于直接调用异步函数,我们可以仅仅 yield 一条描述函数调用的指令,由redux-saga中间件负责解释执行该指令,并在获得结果响应时恢复Generator的执行。...中间件,然后调用run()函数启动你的root saga就大功告成了: import { createStore, applyMiddleware } from 'redux' import createSagaMiddleware

1.7K30

手写Redux-Saga源码

本文要讲的就是Redux-Saga,这个也是我实际工作中使用最多的Redux异步解决方案。...Redux-Saga是一个Redux中间件,所以我们createStore的时候将它引入就行: // store.js import { createStore, applyMiddleware }...runSaga对应的源码看这里:github.com/redux-saga/… proc proc就是具体执行这个迭代器的过程,Generator的执行方式我们之前另一篇文章详细讲过,简单来说就是可以另外写一个方法...Redux-Saga增强了Redux的dispatch函数,dispatch的同时会触发channel.put,也就是让Redux-Saga也响应回调。...整个Redux-Saga都是基于Generator的,每往下走一步都需要手动调用next,这样当他执行到中途的时候我们可以根据情况不再继续调用next,这其实就相当于将当前任务cancel了。

1.7K30

Taro 小程序开发大型实战(六):尝鲜微信小程序云(上篇)

官方把一个 saga 比喻为应用程序中的一个单独的线程,它负责独立的处理副作用, JavaScript 中,副作用就是指异步网络请求、本地读取 localStorage/Cookie 等外界操作。... try 语句中,首先是使用了 redux-saga 提供给我们的 effects helper 函数:call 来调用登录的 API:userApi.login,并把 userInfo 作为参数传给这个...接着,我们使用 redux-saga 提供的 effects helpers 函数:put,put 类似之前 view 中的 dispatch 操作,,来 dispatch 了三个 action:LOGIN_SUCCESS.../effects 包中导入了必要的函数: call: saga 函数中调用其他异步/同步函数,获取结果 put:类似 dispatch,用于 saga 函数中发起 action take: saga...函数中监听 action,并获取对应 action 所携带的数据 fork: saga 函数中无阻塞的调用 handlerSaga,即调用之后,不会阻塞后续的执行逻辑。

2.2K20

使用dva脚手架中使用redux-sage感受

最近在使用了redux进行项目的开发,这个东西确实是把逻辑和页面的展示区分开了,代码的书写上,以及以后的更改代码,提供了更多的方便. dva对redux-saga封装了一层,目前我使用的情况来看还是比较方便的...使用redux-saga进行项目管理里,建议,使用者前,能够充分了解state的不足之处,我能理解react中state的不足之处便是:项目足够大的时候,每个组件之间的相互调用参数,传递参数,给我带来了很多的不便...,比如一个下拉select的数据,A组件中使用需要使用,B组件中也是需要使用的,可是如果没有用redux-saga的话,那么我们就要在A组件中调用一次,B组件中调用一次,又或者是A,B组件中都需要用到同一个接口...,我们只需要调用redux-saga的this.props.dispatch.把方法写到一个js文件中,然后redux-saga中的action中调用,dva里改成了effect,带*的函数了....使用redux-saga中难免会有异步数据同步不来的时候,我一般会把数据的展示和调用放到了render中,前提是componentDidMount 中调用了但是没有数据的展示,实在迫不得已才放到了render

1.1K40

React-Redux-Saga

Redux-saga 简介redux-sagaredux-thunk 一样, 是一个 Redux 中获取存储异步数据的中间件redux-saga 可以直接拦截 dispatch 派发的 action..., 从而实现在执行 reducer 之前执行一些其它操作使用 Redux-saga安装 Redux-saganpm install redux-saga创建 store 时应用 redux-saga...如果导入的是redux-saga, 那么返回给我们的是一个用于创建中间件对象的方法* */import createSagaMiddleware from 'redux-saga'import...如果是redux-saga, 那么除了需要在创建store的时候指定中间件以外, 还需要手动的调用中间件的run方法才行* */sagaMiddleware.run(undefined,...中保存是通过 Saga 提供的 put 方法进行添加即可,更改 store.js 告诉 saga 中间件的生成器哪些通过 dispatch 派发的 action 需要进行拦截, run 方法进行指定

17930

一天梳理完react面试高频题

这种机制可以让我们改变数据流,实现如异步action ,action 过滤,日志输出,异常报告等功能redux-logger:提供日志输出redux-thunk:处理异步操作redux-promise:...传统页面的开发模式中,每次需要更新页面时,都要手动操作 DOM 来进行更新。 DOM 操作非常昂贵。在前端开发中,性能消耗最大的就是 DOM 操作,而且这部分代码会让整体项目的代码变得难 以维护。...redux异步流中间件其实有很多,当下主流的异步中间件有两种redux-thunk、redux-saga。...中间件redux-saga优点:异步解耦: 异步操作被被转移到单独 saga.js 中,不再是掺杂 action.js 或 component.js 中action摆脱thunk function:...redux-saga可以将多个Saga可以串⾏/并⾏组合起来,形成⼀个⾮常实⽤的异步flow易测试,提供了各种case的测试⽅案,包括mock task,分⽀覆盖等等redux-saga缺陷:额外的学习成本

4.1K20

2021高频前端面试题汇总之React篇

Redux 中异步的请求怎么处理 可以 componentDidmount 中直接进⾏请求⽆须借助redux。...redux异步流中间件其实有很多,当下主流的异步中间件有两种redux-thunk、redux-saga。...或者redux-observable额外的范式,上⼿简单 redux-thunk缺陷: 样板代码过多: 与redux本身⼀样,通常⼀个请求需要⼤量的代码,⽽且很多都是重复性质的 耦合严重: 异步操作redux...中间件 redux-saga优点: 异步解耦: 异步操作被被转移到单独 saga.js 中,不再是掺杂 action.js 或 component.js 中 action摆脱thunk function...⽤ 灵活: redux-saga可以将多个Saga可以串⾏/并⾏组合起来,形成⼀个⾮常实⽤的异步flow 易测试,提供了各种case的测试⽅案,包括mock task,分⽀覆盖等等 redux-saga

2K00
领券