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

使用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.2K40

redux-saga学习

如果redux需要用到 side effect 异步操作,redux-thunk 和 redux-saga 绝对是目前两个最受欢迎的中间件插件。...(Generator可以通过next查看每一步的调用结果) Hello redux-saga 主要根据官方案例构建 初始化项目 1.克隆教程仓库 git clone...; } 为了运行我们的 Saga,我们需要: 创建一个 Saga middleware 运行的 Sagas(目前我们只有一个 helloSaga) 将这个 Saga middleware 连接至 Redux...也有可能是运行 Generator 函数并对返回的 Generator 进行迭代的测试代码)。所以调用者得到的是一个 Promise,像在以上的测试代码里一样。...middleware 迭代 在第一次迭代里,middleware 会调用 next() 方法来获取下一个 Effect。与此同时,Generator 将被暂停,直到 effect 执行结束。

2.7K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    手写Redux-Saga源码

    ,只在需要的时候通过put发出action来进行通讯。...,通过他的类型获取对应的处理函数,然后进行处理,我这里代码简化了,只支持IO这种effect,官方源码中还支持promise和iterator,具体的可以看看他的源码:github.com/redux-saga...cb,不需要等待proc的结果 } 复制代码 runPutEffect 我们前面的例子还用到了put这个effect,他就更简单了,只是发出一个action,事实上他也是调用的Redux的dispatch...); } 复制代码 上面这段代码就很好理解了,我们一个死循环不停的监听pattern,即目标事件,当目标事件过来的时候,就执行对应的saga,然后又进入下一次循环继续监听pattern。...整个Redux-Saga都是基于Generator的,每往下走一步都需要手动调用next,这样当他执行到中途的时候我们可以根据情况不再继续调用next,这其实就相当于将当前任务cancel了。

    1.7K30

    高级前端react面试题总结

    UI 的占用空间React Hooks在平时开发中需要注意的问题和原因(1)不要在循环,条件或嵌套函数中调用Hook,必须始终在 React函数的顶层使用Hook这是因为React需要利用调用顺序来正确更新相应的状态...但是每一次父组件渲染子组件即使没变化也会跟着渲染一次。(5)不要滥用useContext可以使用基于 useContext 封装的状态管理工具。React中发起网络请求应该在哪个生命周期中进行?...“适时”地让出 CPU 执行权,除了可以让浏览器及时地响应用户的交互,还有其他好处:分批延时对DOM进行操作,避免一次性操作大量 DOM 节点,可以得到更好的用户体验;给浏览器一点喘息的机会,它会对代码进行编译优化...Redux 请求中间件如何处理并发使用redux-Saga redux-saga是一个管理redux应用异步操作的中间件,用于代替 redux-thunk 的。...两者通过React-Redux 提供connect方法联系起来React如何进行组件/逻辑复用?

    4.1K40

    React-Redux-Saga

    Redux-saga 简介redux-saga 和 redux-thunk 一样, 是一个 Redux 中获取存储异步数据的中间件redux-saga 可以直接拦截 dispatch 派发的 action..., 从而实现在执行 reducer 之前执行一些其它操作使用 Redux-saga安装 Redux-saganpm install redux-saga在创建 store 时应用 redux-saga...如果是redux-saga, 那么除了需要在创建store的时候指定中间件以外, 还需要手动的调用中间件的run方法才行* */sagaMiddleware.run(undefined,...中保存是通过 Saga 提供的 put 方法进行添加即可,在更改 store.js 告诉 saga 中间件的生成器哪些通过 dispatch 派发的 action 需要进行拦截, 在 run 方法进行指定...(博主所说的是:如果派发下一次同类型 action 的时候,上一次派发的 action 还没有处理完, 也就是上一次的监听方法还没有处理完)如果我们只需要保存一个数据, 那么直接通过 yield put

    21430

    前端高频react面试题

    (2)setState 是同步还是异步的假如所有setState是同步的,意味着每执行一次setState时(有可能一个同步代码中,多次setState),都重新vnode diff + dom修改,这对性能来说是极为不好的...如果是异步,则可以把一个同步代码中的多个setState合并成一次组件更新。所以默认是异步的,但是在一些情况下是同步的。setState 并不是单纯同步/异步的,它的表现会因调用场景的不同而不同。...如果每次调用 setState都进行一次更新,那么意味着render函数会被频繁调用,界面重新渲染,这样效率是很低的;最好的办法应该是获取到多个更新,之后进行批量更新;如果同步更新了state,但是还没有执行...redux-saga可以将多个Saga可以串⾏/并⾏组合起来,形成⼀个⾮常实⽤的异步flow易测试,提供了各种case的测试⽅案,包括mock task,分⽀覆盖等等redux-saga缺陷:额外的学习成本...对新旧两棵树进行一个深度优先遍历,这样每一个节点都会一个标记,在到深度遍历的时候,每遍历到一和个节点,就把该节点和新的节点树进行对比,如果有差异就放到一个对象里面遍历差异对象,根据差异的类型,根据对应对规则更新

    3.4K20

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

    显然,大多数的异步任务都需要和外部世界进行交互,不管是发起网络请求、访问本地文件或是数据库等等,因此,它们都会产生“副作用”。 3.什么是redux-saga?...上一篇我们介绍过Redux的中间件,说白了就是在action被传递到reducer之前新进行了一次拦截,然后启动异步任务,等异步任务执行完成后再发送一个新的action,调用reducer修改状态数据。...redux-saga的功能也是一样的,参见下图: 左边的蓝圈圈里就是一堆saga,它们需要和外部进行异步I/O交互,等交互完成后再修改Store中的状态数据。...5.redux-saga用法 根据上一节的分析,我们不仅需要实现一个Generator函数,还需要提供一个外部驱动函数。...因此,相比于直接调用异步函数,我们可以仅仅 yield 一条描述函数调用的指令,由redux-saga中间件负责解释执行该指令,并在获得结果响应时恢复Generator的执行。

    1.7K30

    单向数据流-从共享状态管理:fluxreduxvuex漫谈异步数据处理

    redux Redux使用一个对象存储整个应用的状态(global state),当global state发生变化时,状态从树形结构的最顶端往下传递。每一级都会去进行状态比较,从而达到更新。...redux-saga redux-saga是一个Redux中间件,用来帮你管理程序的副作用。或者更直接一点,主要是用来处理异步action。...redux-saga将进行异步处理的逻辑剥离出来,单独执行,利用generator实现异步处理。...关于saga原理的,推举阅读《前端技术栈(三):redux-saga,化异步为同步》 什么是Saga?...而VUEX即不需要使用外层组件,也不需要类似connect方式将组件做一次包装,我认为出发点应该是可能是为了避免啰嗦。

    3.8K40

    前端二面高频react面试题集锦_2023-02-23

    (5)一次学习,随处编写 无论现在正在使用什么技术栈,都可以随时引入 React来开发新特性,而不需要重写现有代码。...redux异步流中间件其实有很多,当下主流的异步中间件有两种redux-thunk、redux-saga。...⽤ 灵活: redux-saga可以将多个Saga可以串⾏/并⾏组合起来,形成⼀个⾮常实⽤的异步flow 易测试,提供了各种case的测试⽅案,包括mock task,分⽀覆盖等等 redux-saga...⽤到,但是我们依然需要引⼊这些代码 ts⽀持不友好: yield⽆法返回TS类型 redux-saga可以捕获action,然后执行一个函数,那么可以把异步代码放在这个函数中,使用步骤如下: 配置中间件...父组件向子组件的子组件通信,向更深层子组件通信: 使用props,利用中间组件层层传递,但是如果父组件结构较深,那么中间每一层组件都要去传递props,增加了复杂度,并且这些props并不是中间组件自己需要的

    2.8K20

    react项目架构之路初探

    有没有一种方法,可以避免开发者进行重复的造轮子工作,相同的分页逻辑 传值查询功能等 能不能只写一次 从而能够让多个表格共用,且不会互相影响。...,thunks 是在action被创建时调用,而 Sagas只会在应用启动时调用 redux-thunk中间件可以让action创建函数先不返回一个action对象,而是返回一个函数,函数传递两个参数...(dispatch,getState),在函数体内进行业务逻辑的封装 redux-thunk的缺点: action的形式不统一 ,异步操作太分散,分散在了各个action中 redux-saga本质是一个可以自执行的.../saga' // 引入saga中相关组件 import createSagaMiddleware from 'redux-saga' // 引入react-redux相关组件 使redux和react...image 参考文献 React+Redux-Saga+Seamless-Immutable+Reduxsauce后台系统搭建之路 reduxsauce npm地址 redux-saga中文 redux-saga

    2.5K10

    社招前端一面react面试题汇总

    对新旧两棵树进行一个深度优先遍历,这样每一个节点都会一个标记,在到深度遍历的时候,每遍历到一和个节点,就把该节点和新的节点树进行对比,如果有差异就放到一个对象里面遍历差异对象,根据差异的类型,根据对应对规则更新...setState,setState 的批量更新策略会对其进行覆盖,去最后一次的执行,如果是同时 setState 多个不同的值,在更新时会对其进行合并批量更新合成事件中是异步钩子函数中的是异步原生事件中是同步...redux-thunk优点:体积⼩:redux-thunk的实现⽅式很简单,只有不到20⾏代码;使⽤简单:redux-thunk没有引⼊像redux-saga或者redux-observable额外的范式.../catch语法直接捕获处理;功能强⼤:redux-saga提供了⼤量的Saga辅助函数和Effect创建器供开发者使⽤,开发者⽆须封装或者简单封装即可使⽤;灵活:redux-saga可以将多个Saga...redux-observable缺陷:学习成本奇⾼:如果你不会rxjs,则需要额外学习两个复杂的库;社区⼀般:redux-observable的下载量只有redux-saga的1/5,社区也不够活跃,在复杂异步流中间件这个层

    3K20

    redux-saga_pub culture

    用了redux-saga之后: form组件触发提交action (一行简单的dispatch) reducer这个action不需要我处理 (打酱油了) saga提交表单的副作用走起~ (监听到触发副作用的...你可以利用 Redux middleware 来进行日志记录、创建崩溃报告、调用异步接口或者路由等等。 可以简单理解为,中间件是可以在action到达reducer之前做一些事情的层。...比如,我们需要一个刷新按钮, 让用户可以手动的从后台刷新数据, 当用户不停单机刷新的时候, 应该最新一次的请求数据被刷新在页面上,这里可以使用takeLatest。...put方法 put就是redux的dispatch,用来触发reducer更新store 有什么弊端 目前在项目实践中遇到的一些问题: redux-saga模型的理解和学习需要投入很多精力 因为需要用...和reducer之间重复触发,造成死循环 后记 总体而言,对于redux-saga的第一次尝试还是很满意的。

    1.4K10

    React saga_react获取子组件ref

    redux-saga简介 Redux-saga是Redux的一个中间件,主要集中处理react架构中的异步处理工作,被定义为generator(ES6)的形式,采用监听的形式进行工作。...redux-saga安装 使用npm进行安装: npm install --save redux-saga 或者使用yarn: yarn add redux-saga redux-saga常用方法解释...---- 最近将项目中redux的中间件,从redux-thunk替换成了redux-saga,做个笔记总结一下redux-saga的使用心得,阅读本文需要了解什么是redux,redux中间件的用处是什么...唯一不同的是需要调用run方法使得generator可以开始执行。...这个描述对象包含了所需要调用的方法和执行方法时的实际参数,我们认为只要描述对象相同,也就是说只要调用的方法和执行该方法时的实际参数相同,就认为最后执行的结果肯定是满足预期的,这样可以方便的进行单元测试,

    4.5K30

    一文梭穿Vuex、Flux、Redux、Redux-saga、Dva、MobX

    但是因为 React 包含函数式的思想,也是单向数据流,和 Redux 很搭,所以一般都用 Redux 来进行状态管理。...在聊 redux-saga 之前,需要熟悉一些预备知识,那就是 ES6 的 Generator。...Generator 函数的很多代码可以被延缓执行,也就是具备了暂停和记忆的功能:遇到yield表达式,就暂停执行后面的操作,并将紧跟在yield后面的那个表达式的值,作为返回的对象的value属性值,等着下一次调用...用了 saga,我们就可以很细粒度的控制各个副作用每一部的操作,可以把异步操作和同步发起 action 一起,随便的排列组合。...的每一步都可以做一些断言(assert)之类的,所以非常方便测试。

    5.5K10

    dva

    简言之:dva想提供一个基于业界react&redux最佳实践的业务框架,以解决用裸redux全家桶作为前端数据层带来的种种问题 编辑成本高,需要在reducer, saga, action之间来回切换...saga书写太复杂,每监听一个action都需要走fork -> watcher -> worker的流程 redux entry书写麻烦,要完成store创建,中间件配置,路由初始化,Provider...依赖关系 dva react react-dom dva-core redux redux-saga history react-redux react-router-redux...model配置得到reducers,worker sagas, states后,屏蔽接下来的一系列繁琐工作: 接redux(组合state,组合reducer) 接redux-saga(完成redux-saga...围绕一个连接点的增强,如方法调用。这是最强大的一种增强类型。环绕增强可以在方法调用前后完成自定义的行为。

    1.9K50

    高频React面试题及详解

    ,这造成了多余的请求,其次,在React 16进行React Fiber重写后,componentWillMount可能在一次渲染中多次调用....,取最后一次的执行,如果是同时setState多个不同的值,在更新时会对其进行合并批量更新。...功能孱弱: 有一些实际开发中常用的功能需要自己进行封装 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

    2.4K40

    前端react面试题(必备)2

    对新旧两棵树进行一个深度优先遍历,这样每一个节点都会一个标记,在到深度遍历的时候,每遍历到一和个节点,就把该节点和新的节点树进行对比,如果有差异就放到一个对象里面遍历差异对象,根据差异的类型,根据对应对规则更新...) 返回false 那么不能保证Context的更新一定可以使用Context的子组件,因此,Context的可靠性需要关注调和阶段 setState内部干了什么当调用 setState 时,React...redux异步流中间件其实有很多,当下主流的异步中间件有两种redux-thunk、redux-saga。...redux-observable额外的范式,上⼿简单redux-thunk缺陷:样板代码过多: 与redux本身⼀样,通常⼀个请求需要⼤量的代码,⽽且很多都是重复性质的耦合严重: 异步操作与redux的...redux-saga可以将多个Saga可以串⾏/并⾏组合起来,形成⼀个⾮常实⽤的异步flow易测试,提供了各种case的测试⽅案,包括mock task,分⽀覆盖等等redux-saga缺陷:额外的学习成本

    2.3K20

    状态管理的概念,都是纸老虎

    但是因为 React 包含函数式的思想,也是单向数据流,和 Redux 很搭,所以一般都用 Redux 来进行状态管理。...在聊 redux-saga 之前,需要熟悉一些预备知识,那就是 ES6 的 Generator。...Generator 函数的很多代码可以被延缓执行,也就是具备了暂停和记忆的功能:遇到yield表达式,就暂停执行后面的操作,并将紧跟在yield后面的那个表达式的值,作为返回的对象的value属性值,等着下一次调用...用了 saga,我们就可以很细粒度的控制各个副作用每一部的操作,可以把异步操作和同步发起 action 一起,随便的排列组合。...的每一步都可以做一些断言(assert)之类的,所以非常方便测试。

    5.3K20
    领券