注意:老铁些,在看这篇文章的之前,最好了解一下react 的全局状态管理库哦,不然可能会坐飞机。 ^_^

React 之reflux (它是一个功能模块,需要安装引入):

import Reflux from 'reflux';

let action = Reflux.createAction();//1使用

let actions = Reflux.createActions(['add','delete','check']);//1使用

let store = Reflux.createStore({});//1使用

  1. 创建action和store:

    1.1:reflux.createAction(): 创建一个action;返回值是一个函数,调用这个函数就会触发相应的事件,在store中监听这个函数,并作相 应的处理。

      reflux.createActions([]):创建多个action;返回值是一个对象,包含多个函数。

    1.2:reflux.createStore({}); 创建store实例,返回一个对象。

     1.3:创建action方法的公用方法,reflux.ActionMethods.pck = function(){};  。//pck方法是你要创建的公用方法

      单个action使用公用方法:action.pck();

      多个action使用公用方法:actions.add.pck();

     1.4:创建Store的公用方法,reflux.StoreMethods.pck = function(){};  。

     1.5:拓展store的公用方法:

      1.5.1:reflux.StoreMethods.pck = function(){};  //pck是定义的方法名。

      1.5.2:let mixin = { pck: function(){} };

            let store = reflux.createStore({  mixins:[mixin], ...});

===============================================================================================================================

    2. Store监听Action:

    let actions = reflux.createActions([ ‘add’, ‘delete’, ‘check’]);

    let actions1 = reflux.createAction();

    let store = reflux.createStore({  init: function(){}, ...});

    2.1:this.listenTo( actions.add, “add”); 第一个参数是actions对象的方法。第二个参数是store对象监听action的方法调用的方法名。如果是actions1的话,那么 写法就是this.listenTo( actions1, “actions1”); first和second参数名不需要一致。

    2.2:this.listenToMany(actions); 参数actions必须是json对象。

        处理方法的写法只需让action 的标识首字母大写并加上on 就可以了。例如:add→onAdd。

    2.3:listenables: [actions];  属性值actions必须是json对象。

        处理方法的写法只需让action的标识首字母大写并加上on就可以了。例如:add→onAdd。

    注意:2.1和2.2都是写在init函数内部,2.3方法是属性写法,listenables是配置   属性。并且2.2和2.3的参数或者属性值必须是 createActions  创建的action,也就是actions。

===============================================================================================================================

    3. 异步action :let asyncAction = Reflux.createAction({asyncResult: true});

         

===============================================================================================================================

    4. Action hooks:Reflux为每个action 方法都提供了两个hook方法。

    4.1:preEmit(params) ,action emit之前调用,参数是action传递过来的,返回值 会传递给shouldEmit();

    4.2:shouldEmit(params) ,action emit之前调用,参数默认是action传递,如果 preEmit有返回值,则是preEmit返回值;shouldEmit()的返回值决定是否 触发action事件。

    4.3:注意,如果preEmit有返回值,则该返回值会作为action事件的参数;否则就是action的初始参数;不论shouldEmit的返回值是什么,它只是决定是否触 发action事件。

===============================================================================================================================

    5. 同组件结合:

    let store = Reflux.createStore({});

    5.1:store.listen(func);  func:被监听的函数。返回值是解除store监听的一个函数。

      5.1.1:当组件的生命周期结束时需要解除对Store的监听。

      5.1.2: 当Store调用trigger时,才会执行func函数,所以每次Store    更新时,需要手动调用trigger函数。

      5.1.3:并且store.trigger(params); 的参数将是func的参数(如果有)。

    5.2:mixins: [Reflux.ListenerMixin]  +  store.listen(func);

      5.2.1:适用于作为React.createClass({})的配置属性。

     例如:let test = React.createClass({ mixins: [Reflux.ListenerMixin] }); (首字母大写  ListenerMixin)

      5.2.2:接下来的写法和5.1方法一样,不过没有了5.1.1的限制。

    5.3:mixins: [Reflux.listenTo(store, “func”)]

      5.3.1:适用于作为React.createClass({})的配置属性。

     例如:let test = React.createClass({mixins: [Reflux.listenTo(store, “func”)] });

      5.3.2:它比5.2更优化的是,没有了store.listen(func); 但是也必须要手动触发   store.trigger();

    5.4:minxins: [Reflux.connect(store, ‘list’)]

      5.4.1:它相对应5.3来说,优化了一点,也就是不需要函数来更新state里面   的list,但是还是必须手动触发store.trigger()。

      5.4.2:注意,这里的‘list’参数是state里面的属性名(被监听的)。

    5.5:mixins: [Reflux.connectFilter(store, ‘list’, function(list){})];

      5.5.1:相对于5.4来说,只是增加了一个数据过滤器。

      5.5.2:第三个参数就是过滤函数。参数名不必和第二个参数名相同。

      5.5.3:还是必须要手动触发 store.trigger(); 。

总结:这5种结合的方法,都必须手动触发store.trigger(); ;

5.4方法与5.5方法的第二个参数名必须和state里面的属性(被监听)名一   致(字符串)。

各位老铁,有错误的地方欢迎指正,多多指教了。^_^

react 之 reflux 填坑的更多相关文章

  1. React Native填坑之旅--Stateless组件

    Stateless component也叫无状态组件.有三种方法可以创建无状态组件. 坑 一般一个组件是怎么定义的: 很久以前的方法: const Heading = createClass({ re ...

  2. React Native填坑之旅--与Native通信之iOS篇

    终于开始新一篇的填坑之旅了.RN厉害的一个地方就是RN可以和Native组件通信.这个Native组件包括native的库和自定义视图,我们今天主要设计的内容是native库方面的只是.自定义视图的使 ...

  3. React Native填坑之旅--Flow篇(番外)

    flow不是React Native必会的技能,但是作为正式的产品开发优势很有必要掌握的技能之一.所以,算是RN填坑之旅系列的番外篇. Flow是一个静态的检查类型检查工具,设计之初的目的就是为了可以 ...

  4. React Native填坑之旅--重新认识RN

    如同黑夜里的一道光一样,就这么知道了F8. F8是每年一次Facebook每年一次的开发者大会.每次大会都会release相应的APP,iOS.Android都有.之前都是用Native开发的,但是2 ...

  5. React Native填坑之旅--布局篇

    代码在这里: https://github.com/future-challenger/petshop/tree/master/client/petshop/src/controller 回头看看RN ...

  6. React Native填坑之旅--Navigation篇

    React Native的导航有两种,一种是iOS和Android通用的叫做Navigator,一种是支持iOS的叫做NavigatorIOS.我们这里只讨论通用的Navigator.会了Naviga ...

  7. React Native填坑之旅--ListView篇

    列表显示数据,基本什么应用都是必须.今天就来从浅到深的看看React Native的ListView怎么使用.笔者写作的时候RN版本是0.34. 最简单的 //@flow import React f ...

  8. React Native填坑之旅--动画

    动画是提高用户体验不可缺少的一个元素.恰如其分的动画可以让用户更明确的感知当前的操作是什么. 无疑在使用React Native开发应用的时候也需要动画.这就需要知道RN都给我们提供了那些动画,和每个 ...

  9. React Native填坑之旅--Button篇

    从React过来,发现React Native(以下简称RN)居然没有Button.隔壁的iOS是有UIButton的,隔壁的隔壁的Android里也是有的.没有Button,就没有点击效果啊.这还真 ...

随机推荐

  1. zepto中的属性设置

    上次看zepto的init方法时,有一段属性设置的代码,先来看看其表现: if (isPlainObject(properties)) { nodes = $(dom) $.each(properti ...

  2. TensorFlow(3)CNN中的函数

    tf.nn.conv2d()函数 参数介绍: tf.nn.conv2d(input, filter, strides, padding, use_cudnn_on_gpu=None, name=Non ...

  3. 【转载】PhpStudy修改Apache的端口号

    phpStudy是一个PHP调试环境的程序集成包.该程序包集成最新的Apache+PHP+MySQL+phpMyAdmin+ZendOptimizer,一次性安装,无须配置即可使用,是非常方便.好用的 ...

  4. ASP.NET MVC 学习笔记-7.自定义配置信息(后续)

    自定义配置信息的高级应用 通过上篇博文对简单的自定义配置信息的学习,使得更加灵活的控制系统配置信息.实际项目中,这种配置的灵活度往往无法满足项目的灵活度和扩展性. 比如,一个配置信息有三部分组成,而每 ...

  5. Laravel5性能优化技巧

    分享一些 Laravel 开发的最佳实践,还有调优技巧,后面陆续整理中 1.配置缓存信息 使用laravel自带的artisan命令,将所有config里面的配置都缓存到一个文件里. php arti ...

  6. struts2_struts.xml配置文件讲解

    1.bean Bean详细讲解:https://www.cnblogs.com/lulu638/p/4340703.html 2.constant constant属性配置,可配置的属性可以参考def ...

  7. DoTween 动画插件简单示例

    .doTween的静态方法 DOTween.To(() => maskImage.color, toColor => maskImage.color = toColor, , , , ), ...

  8. LNMP 一键安装 yum install php-mcrypt libmcrypt libmcrypt-devel

    centos源不能安装libmcrypt-devel,由于版权的原因没有自带mcrypt的包 有两种方法解决,一种是使用第三方源,这样还可以使用yum来安装,简单方便,坏处是第三方源多少有中不可靠的感 ...

  9. vim编辑器的设置

    1.vim编辑器设置分为两种设置,临时设置和永久设置 2.临时设置开启和关闭高亮模式(目前高亮模式是开启的) etc/ man.config vim man.config 在文本编辑器中命令行模式下输 ...

  10. Andorid 刷新样式一

    一.Gradle中的Build.gradle依赖项目 compile 'com.github.moduth:blockcanary-android:1.1.0' debugCompile 'com.s ...