注意:老铁些,在看这篇文章的之前,最好了解一下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. Perl面向对象(1):从代码复用开始

    官方手册:http://perldoc.perl.org/perlobj.html 本系列: Perl面向对象(1):从代码复用开始 Perl面向对象(2):对象 Perl面向对象(3):解构--对象 ...

  2. linux四剑客-grep/find/sed/awk/详解-技术流ken

    四剑客简介 相信接触过linux的大家应该都学过或者听过四剑客,即sed,grep,find,awk,有人对其望而生畏,有人对其爱不释手.参数太多,变化形式太多,使用超级灵活,让一部分人难以适从继而望 ...

  3. 【转】没那么难,谈CSS的设计模式

    什么是设计模式? 曾有人调侃,设计模式是工程师用于跟别人显摆的,显得高大上:也曾有人这么说,不是设计模式没用,是你还没有到能懂它,会用它的时候. 先来看一下比较官方的解释:“设计模式(Design p ...

  4. SharedPreferences存储读取数据

    存储 //创建SharedPreferences 存储用户名SharedPreferences sharedPreferences = getSharedPreferences("name& ...

  5. 将汉字转化为拼音的js插件

    /*---------------------------------------------------------------- // 文件名:chinese2pinyin.js // 文件功能描 ...

  6. 第三讲 smart qq 登录成功后获取 vfwebqq ,psessionid,hash

    public static void Login_GetPHV() { string urldata = "{\"ptwebqq\":\"#{ptwebqq}\ ...

  7. D. GukiZ and Binary Operations(矩阵+二进制)

    D. GukiZ and Binary Operations   We all know that GukiZ often plays with arrays. Now he is thinking ...

  8. Java 原生网络编程.

    一.概念 Java 语言从其诞生开始,就和网络紧密联系在一起.在 1995 年的 Sun World 大会上,当时占浏览器市场份额绝对领先的网景公司宣布在浏览器中支持Java,从而引起一系列的公司产品 ...

  9. js canvas 转动时钟实例

    源码:https://pan.baidu.com/s/1R12MwZYs0OJw3OWKsc8WNw 样本:http://js.zhuamimi.cn/shizhong/ 我的百度经验:https:/ ...

  10. Laravel 系列入门教程(五)【最适合中国人的 Laravel 教程】

    本文是本系列教程的完结篇,我们将一起给 Article 加入评论功能,让游客在前台页面可以查看.提交.回复评论,并完成后台评论管理功能,可以删除.编辑评论.Article 和评论将使用 Laravel ...