关于redux-saga中take使用方法详解


Posted in Javascript onFebruary 27, 2018

本文介绍了关于redux-saga中take使用方法详解,分享给大家,具体如下:

带来一个自己研究好久的API使用方法.

redux-saga中effect中take这个API使用方式,用的多的是call,put,select,但take这个平常还真没什么机会用上,也不清楚在哪里使用才好,不管怎么样,既然是redux-saga写出来的,肯定是有他的用法的,不管37 21,先学会使用方法再说.

先看看介绍:

take

take的表现同takeEvery一样,都是监听某个action,但与takeEvery不同的是,他不是每次action触发的时候都相应,而只是在执行顺序执行到take语句时才会相应action。

当在genetator中使用take语句等待action时,generator被阻塞,等待action被分发,然后继续往下执行。

takeEvery只是监听每个action,然后执行处理函数。对于何时相应action和 如何相应action,takeEvery并没有控制权。

而take则不一样,我们可以在generator函数中决定何时相应一个action,以及一个action被触发后做什么操作。

最大区别:take只有在执行流达到时才会响应对应的action,而takeEvery则一经注册,都会响应action。

上代码:

effects: {
 * takeDemo1({payload}, {put, call, take}) {

 },
 * takeInputChange({payload}, {put, call, take,takeEvery,takeLatest}) {
  // yield call(delay,1000);
  console.log(takeEvery);
  // for (let i = 0; i < 3; i++) {
   const action = yield take('takeBlur'});
   console.log(action, 'action');
   console.log(payload.value);
  // }

 },
 * takeBlur() {
  console.log(323)
 },
}
changeHandle(e){
 this.props.dispatch({type:'takeInputChange',payload:{value:e.target.value}})
}
blur(){
 this.props.dispatch({type:'takeBlur'})
}
render() {

 return (
  <div style={{position: 'relative'}}>
   <Input onChange={this.changeHandle.bind(this)} onBlur={this.blur.bind(this)}/> 
  </div>
  )
}

页面上有一个input,绑定了两个方法,第一个是onchange方法,一个是onBlur方法,

当input值改变 的时候,通过 this.props.dispatch({type:'takeInputChange'}),调用此函数,但是因为遇到了take的方法,不能往下继续执行了(暂停了),如果这里的take换成了takeEvery则大有不同,函数会继续执行,就是下面的两个console会执行,

而takeEvery执行的方法则放在它的回调里了,看下面代码

yield takeEvery('takeBlur',()=>{console.log(payload.value)});

需要强调的是每次input改变的时候都会触发这个函数,所以每次改变的时候,会看到控制台都会打印一次console里的值.

接下来,如果input失去焦点后,则会执行onBlur方法,此时调用this.props.dispatch({type:'takeBlur'});

在takeInputChange里的take因为监听到了takeBlur这个action,那么就会继续执行需要执行的内容.

这个take反正是研究了还算长的时间,不知道这个东西在哪些时候能够派的上用场

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript appendChild,innerHTML,join性能比较代码
Aug 29 Javascript
jquery表单验证框架提供的身份证验证方法(示例代码)
Dec 27 Javascript
jquery比较简洁的软键盘特效实现方法
Mar 19 Javascript
jQuery+json实现的简易Ajax调用实例
Dec 14 Javascript
通过jquery-ui中的sortable来实现拖拽排序的简单实例
May 24 Javascript
动态加载js、css的简单实现代码
May 26 Javascript
举例讲解jQuery对DOM元素的向上遍历、向下遍历和水平遍历
Jul 07 Javascript
微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(二)
May 11 Javascript
vue router+vuex实现首页登录验证判断逻辑
May 17 Javascript
vue中选项卡点击切换且能滑动切换功能的实现代码
Nov 25 Javascript
微信小程序如何实现精确的日期时间选择器
Jan 21 Javascript
vue项目实现多语言切换的思路
Sep 17 Javascript
浅析Visual Studio Code断点调试Vue
Feb 27 #Javascript
angularJs 表格添加删除修改查询方法
Feb 27 #Javascript
ExtJs整合Echarts的示例代码
Feb 27 #Javascript
angularJS实现动态添加,删除div方法
Feb 27 #Javascript
浅谈React中的元素、组件、实例和节点
Feb 27 #Javascript
AngularJS动态添加数据并删除的实例
Feb 27 #Javascript
JS严格模式知识点总结
Feb 27 #Javascript
You might like
让ThinkPHP支持大小写url地址访问的方法
2014/10/31 PHP
js下将字符串当函数执行的方法
2011/07/13 Javascript
JavaScript 事件绑定及深入
2015/04/13 Javascript
jQuery+css实现的时钟效果(兼容各浏览器)
2016/01/27 Javascript
jQuery实现鼠标选文字发新浪微博的方法
2016/04/02 Javascript
jQuery.datatables.js插件用法及api实例详解
2016/10/28 Javascript
Vue实现动态显示textarea剩余字数
2017/05/22 Javascript
详解Vue组件之间的数据通信实例
2017/06/17 Javascript
vue.js实现简单的计算器功能
2020/02/22 Javascript
Auto.JS实现抖音刷宝等刷视频app,自动点赞,自动滑屏,自动切换视频功能
2020/05/08 Javascript
解决Echarts 显示隐藏后宽度高度变小的问题
2020/07/19 Javascript
在vue-cli创建的项目中使用sass操作
2020/08/10 Javascript
如何构建一个Vue插件并生成npm包
2020/10/26 Javascript
python类和函数中使用静态变量的方法
2015/05/09 Python
python抓取百度首页的方法
2015/05/19 Python
python中安装模块包版本冲突问题的解决
2017/05/02 Python
不可错过的十本Python好书
2017/07/06 Python
Python使用type关键字创建类步骤详解
2019/07/23 Python
django自带调试服务器的使用详解
2019/08/29 Python
python Django框架实现web端分页呈现数据
2019/10/31 Python
Python利用逻辑回归模型解决MNIST手写数字识别问题详解
2020/01/14 Python
解决TensorFlow训练内存不断增长,进程被杀死问题
2020/02/05 Python
python单元测试框架pytest的使用示例
2020/10/07 Python
英国著名的化妆品折扣网站:Allbeauty.com
2016/07/21 全球购物
德国苹果商店:MacTrade
2020/05/18 全球购物
blueseventy官网:铁人三项和比赛泳衣
2021/02/06 全球购物
自荐信的禁忌和要点
2013/10/15 职场文书
车间机修工岗位职责
2014/02/28 职场文书
化学系大学生自荐信范文
2014/03/01 职场文书
预备党员的自我评价
2014/03/12 职场文书
希特勒的演讲稿
2014/05/23 职场文书
分公司总经理岗位职责
2014/08/03 职场文书
煤矿安全协议书
2014/08/20 职场文书
旅游活动总结
2014/08/27 职场文书
2015年入党积极分子评语
2015/03/26 职场文书
工作证明格式范文
2015/06/15 职场文书