一.什么是redux-actions

   redux-actions是一个简化action和reducer创建的一个封装库,里面有5个js文件,

   createAction.js

   handleAction.js

   handleActions.js

   index.js

   ownKeys.js

二.怎么使用?下面将从源码一一解释每个文件的的用处

  1.createAction.js

    从名字就可以看出,这是用来创建action的.其源码如下:

      

 /**
* 参数不是function调用此函数
*/
function identity(t) {
return t;
} /**
* 创建action
* @param type action的类型
* @param actionCreator 需要创建的action,函数
* @param metaCreator action的属性
* @returns {Function}
*/
export default function createAction(type, actionCreator, metaCreator) {
/**
* finalActionCreator最终创建的action,
* 判断传进来的参数是不是function,true返回这个函数,false调用identity函数
*/
const finalActionCreator = typeof actionCreator === 'function'
? actionCreator
: identity;
/**
* 返回一个匿名函数
*/
return (...args) => {
/**
*创建的action,只有两个属性
*/
const action = {
type,
payload: finalActionCreator(...args)
};
/**
* 如果给匿名函数传递参数的长度为1个,或者第一个参数元素的类型为Error,那么这么action的error属性为true
*/
if (args.length === 1 && args[0] instanceof Error) {
// Handle FSA errors where the payload is an Error object. Set error.
action.error = true;
}
/**
* 传递到action里面的函数
*/
if (typeof metaCreator === 'function') {
action.meta = metaCreator(...args);
} return action;
};
}

  2.handleAction.js

    操作action,源码如下:

    

 import { isError } from 'flux-standard-action';
/**
* 判断是不是function
*/
function isFunction(val) {
return typeof val === 'function';
}
/**
* 处理action
* @param type action类型
* @param 所有的reducers
* @returns {Function}
*/
export default function handleAction(type, reducers) {
return (state, action) => {
// If action type does not match, return previous state
if (action.type !== type) return state; const handlerKey = isError(action) ? 'throw' : 'next'; // If function is passed instead of map, use as reducer
if (isFunction(reducers)) {
reducers.next = reducers.throw = reducers;
} // Otherwise, assume an action map was passed
const reducer = reducers[handlerKey]; return isFunction(reducer)
? reducer(state, action)
: state;
};
}

    reduce-reducers源码:

 export default function reduceReducers(...reducers) {
return (previous, current) =>
reducers.reduce(
(p, r) => r(p, current),
previous
);
}

  3.handleActions.js 

    将所有的action集中在一起处理

    

 import handleAction from './handleAction';
import ownKeys from './ownKeys';
import reduceReducers from 'reduce-reducers'; /**
*
* @param handlers 所有的action
* @param defaultState 初始的state
* @returns {Function} 返回reducer
*/
export default function handleActions(handlers, defaultState) {
const reducers = ownKeys(handlers).map(type => {
return handleAction(type, handlers[type]);
});
/**
* 处理过后的reduce
*/
const reducer = reduceReducers(...reducers) return typeof defaultState !== 'undefined'
? (state = defaultState, action) => reducer(state, action)
: reducer;
}

  4.ownKeys.js

    用于判断对象属性的工具

   

 export default function ownKeys(object) {
/**
* Reflect.ownKeys类似于Object.keys(),返回对象中可枚举的属性
*/
if (typeof Reflect !== 'undefined' && typeof Reflect.ownKeys === 'function') {
return Reflect.ownKeys(object);
}
/**
* 返回对象自己(非原型继承的属性)的属性名称,包括函数。
* Object.keys只适用于可枚举的属性,而Object.getOwnPropertyNames返回对象自己的全部属性名称。
*/
let keys = Object.getOwnPropertyNames(object);
/**
* getOwnPropertySymbols
* 返回Symbol类型的属性
*/
if (typeof Object.getOwnPropertySymbols === 'function') {
keys = keys.concat(Object.getOwnPropertySymbols(object));
} return keys;
}

  5.index.js

    输出所有的函数

  

 import createAction from './createAction';
import handleAction from './handleAction';
import handleActions from './handleActions'; export {
createAction,
handleAction,
handleActions
};

    

redux-actions源码解读的更多相关文章

  1. redux:applyMiddleware源码解读

    前言: 笔者之前也有一篇关于applyMiddleware的总结.是applyMiddleware的浅析. 现在阅读了一下redux的源码.下面说说我的理解. 概要源码: step 1:  apply ...

  2. 通过ES6写法去对Redux部分源码解读

    在Redux源码中主要有四个文件createStore,applyMiddleware,bindActionCreators,combineRedures createStore.js export ...

  3. redux源码解读(一)

    redux 的源码虽然代码量并不多(除去注释大概300行吧).但是,因为函数式编程的思想在里面体现得淋漓尽致,理解起来并不太容易,所以准备使用三篇文章来分析. 第一篇,主要研究 redux 的核心思想 ...

  4. Redux 源码解读 —— 从源码开始学 Redux

    已经快一年没有碰过 React 全家桶了,最近换了个项目组要用到 React 技术栈,所以最近又复习了一下:捡起旧知识的同时又有了一些新的收获,在这里作文以记之. 在阅读文章之前,最好已经知道如何使用 ...

  5. redux源码解读

    react在做大型项目的时候,前端的数据一般会越来越复杂,状态的变化难以跟踪.无法预测,而redux可以很好的结合react使用,保证数据的单向流动,可以很好的管理整个项目的状态,但是具体来说,下面是 ...

  6. redux源码解读(二)

    之前,已经写过一篇redux源码解读(一),主要分析了 redux 的核心思想,并用100多行代码实现一个简单的 redux .但是,那个实现还不具备合并 reducer 和添加 middleware ...

  7. 【原】Spark中Job的提交源码解读

    版权声明:本文为原创文章,未经允许不得转载. Spark程序程序job的运行是通过actions算子触发的,每一个action算子其实是一个runJob方法的运行,详见文章 SparkContex源码 ...

  8. redux的源码解析

    一. redux出现的动机 1. Javascript 需要管理比任何时候都要多的state2. state 在什么时候,由于什么原因,如何变化已然不受控制.3. 来自前端开发领域的新需求4. 我们总 ...

  9. SDWebImage源码解读之SDWebImageDownloaderOperation

    第七篇 前言 本篇文章主要讲解下载操作的相关知识,SDWebImageDownloaderOperation的主要任务是把一张图片从服务器下载到内存中.下载数据并不难,如何对下载这一系列的任务进行设计 ...

  10. SDWebImage源码解读 之 NSData+ImageContentType

    第一篇 前言 从今天开始,我将开启一段源码解读的旅途了.在这里先暂时不透露具体解读的源码到底是哪些?因为也可能随着解读的进行会更改计划.但能够肯定的是,这一系列之中肯定会有Swift版本的代码. 说说 ...

随机推荐

  1. linux增加自定义path和manpath

    linux安装软件到自定义路径时,新安装的命令需要带上路径才可以执行,不能像系统自带命令那样可以直接使用. 这个时候可以通过修改环境变量PATH和MANPATH,来实现像系统命令一样使用新安装的命令并 ...

  2. 使用virtualenv搭建独立的Python环境

    virtualenv可以搭建虚拟且独立的python环境,可以使每个项目环境与其他项目独立开来,保持环境的干净,解决包冲突问题. 一.安装virtualenv virtualenv实际上是一个pyth ...

  3. macosx zsh下安装rvm和ruby

    1)curl -L get.rvm.io | bash -s stable 2)把下面一行加到~/.zshrc中: [[ -s "$HOME/.rvm/scripts/rvm" ] ...

  4. 【Hibernate】Hibernate系列2之Session详解

    Session详解 2.1.概述-一级缓存 2.2.操作session缓存方法 2.3.数据库隔离级别 2.4.持久化状态 2.5.状态转换 2.6.存储过程与触发器

  5. Java for LeetCode 033 Search in Rotated Sorted Array

    Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 2 4 5 6 7 migh ...

  6. ASP.Net和新对象之context.Server

    描述 Server是一个HttpServerUtility类型的对象,不是一个类名 1.获取服务器上的绝对路径文件名tring ss = context.Server.MapPath("~/ ...

  7. ubuntu下简单的驱动编译

    转自:http://www.eefocus.com/jefby1990/blog/13-02/291628_c39b8.html 本文是参考了网上多篇帖子而写的算不上什么原创.唯一值得欣慰的只不过在本 ...

  8. Xamarin Studio支持TypeScript开发

    之前谈到"TypeScript的崛起",今天推荐的文章又再次支持了这一观点--Xamarin Studio也开始支持TypeScript的开发. 一个语言是否能够崛起,很重要的一个 ...

  9. Python开发的10个小贴士

    下面是十个Python中很有用的贴士和技巧.其中一些是初学这门语言常常会犯的错误. 注意:假设我们都用的是Python 3 1. 列表推导式 你有一个list:bag = [1, 2, 3, 4, 5 ...

  10. 虚拟机下运行linux通过nat模式与主机通信、与外网连接

    首先:打开虚拟机的编辑菜单下的虚拟网络编辑器,选中VMnet8 NAT模式.通过NAT设置获取网关IP,通过DHCP获取可配置的IP区间.同时,将虚拟机的虚拟机菜单的设置选项中的网络适配器改为NAT模 ...