关于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 相关文章推荐
YUI模块开发原理详解
Nov 18 Javascript
在页面上用action传递参数到后台出现乱码的解决方法
Dec 31 Javascript
Javascript学习笔记之 函数篇(二) : this 的工作机制
Jun 24 Javascript
javascript中的正则表达式使用指南
Mar 01 Javascript
jQuery实现3D文字特效的方法
Mar 10 Javascript
jQuery实现高亮显示的方法
Mar 10 Javascript
详谈$.data()的用法和作用
Feb 13 Javascript
分析JavaScript数组操作难点
Dec 18 Javascript
JS实现运动缓冲效果的封装函数示例
Feb 18 Javascript
vscode下的vue文件格式化问题
Nov 28 Javascript
解决vue+ element ui 表单验证有值但验证失败问题
Jan 16 Javascript
详谈Vue.js框架下main.js,App.vue,page/index.vue之间的区别
Aug 12 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
PHP实现显示照片exif信息的方法
2014/07/11 PHP
smarty内置函数foreach用法实例
2015/01/22 PHP
PHP延迟静态绑定使用方法实例解析
2020/09/05 PHP
jquery鼠标放上去显示悬浮层即弹出定位的div层
2014/04/25 Javascript
jQuery简单实现隐藏以及显示特效
2015/02/26 Javascript
jQuery实现手机自定义弹出输入框
2016/06/13 Javascript
微信JS接口大全
2016/08/25 Javascript
vue.js实现仿原生ios时间选择组件实例代码
2016/12/21 Javascript
hovertree插件实现二级树形菜单(简单实用)
2016/12/28 Javascript
Vue常用指令V-model用法
2017/03/08 Javascript
vue项目中引入vue-datepicker插件的详解
2019/05/14 Javascript
mpvue实现小程序签到金币掉落动画(api实现)
2019/10/17 Javascript
js实现左右轮播图
2020/01/09 Javascript
DWR内存兼容及无法调用问题解决方案
2020/10/16 Javascript
[03:40]DOTA2亚洲邀请赛小组赛第二日 赛事回顾
2015/01/31 DOTA
[05:16]《大圣!大圣》——DOTA2新英雄齐天大圣配音李世宏老师专访
2016/12/13 DOTA
python使用内存zipfile对象在内存中打包文件示例
2014/04/30 Python
Python中字典的基本知识初步介绍
2015/05/21 Python
Python二分查找详解
2015/09/13 Python
Python使用Phantomjs截屏网页的方法
2018/05/17 Python
基于Python3.6+splinter实现自动抢火车票
2018/09/25 Python
python基础梳理(一)(推荐)
2019/04/06 Python
简单了解python数组的基本操作
2019/11/26 Python
python读写文件write和flush的实现方式
2020/02/21 Python
Python中的wordcloud库安装问题及解决方法
2020/05/27 Python
世界上最具创新性的增强型知名运动品牌:Proviz
2018/04/03 全球购物
搬家公司的创业计划书
2014/01/01 职场文书
端午节演讲稿
2014/05/23 职场文书
股份合作协议书
2014/09/10 职场文书
党员评议表自我评价范文
2014/10/20 职场文书
酒店保洁员岗位职责
2015/02/26 职场文书
学雷锋活动简报
2015/07/20 职场文书
会计主管竞聘书
2015/09/15 职场文书
装修安全责任协议书
2016/03/22 职场文书
导游词范文之颐和园/重庆/云台山
2019/09/10 职场文书
MySQL基础(二)
2021/04/05 MySQL