首页
|
新闻
|
新品
|
文库
|
方案
|
视频
|
下载
|
商城
|
开发板
|
数据中心
|
座谈新版
|
培训
|
工具
|
博客
|
论坛
|
百科
|
GEC
|
活动
|
主题月
|
电子展
注册
登录
论坛
博客
搜索
帮助
导航
默认风格
uchome
discuz6
GreenM
»
MCU 单片机技术
»
PowerPC
» Redux 简介(2)
返回列表
回复
发帖
发新话题
发布投票
发布悬赏
发布辩论
发布活动
发布视频
发布商品
Redux 简介(2)
发短消息
加为好友
look_w
当前离线
UID
1066743
帖子
8283
精华
0
积分
4142
阅读权限
90
在线时间
233 小时
注册时间
2017-6-23
最后登录
2019-5-18
论坛元老
UID
1066743
1
#
打印
字体大小:
t
T
look_w
发表于 2018-11-18 19:31
|
只看该作者
Redux 简介(2)
操作、缩减程序和存储在图 1 中,一个简单的 Redux 示例(一个交通信号灯模拟器)的代码在 TextMate 文本编辑器中运行。图中 TextMate 生成的工具提示显示了应用程序的输出,其中显示了应用程序的状态(STOP、CAUTION 或 GO)。
图 1. 使用 Redux 的交通信号灯状态
图 1 中的代码首先要求使用 Redux 并创建 Redux 存储:
1
2
3
const Redux = require('redux');
const createStore = Redux.createStore;
const store = createStore(reducer);
使用 Redux.createStore() 函数创建应用程序的存储。每个 Redux 应用程序仅有一个存储,每个存储仅有一个缩减程序。将该缩减程序传递给 Redux.createStore() 函数。
应用程序的状态(在本例中为一个具有值 GO、STOP 或 CAUTION 的字符串)由 reducer() 函数创建。reducer() 函数根据当前状态和某个描述状态更改的操作来返回一个新状态。清单 1 给出了交通信号灯应用程序的缩减程序。请注意,在状态未定义时(也就是初始状态),reducer() 函数将返回 GO。
清单 1. 交通信号灯应用程序的缩减程序
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
const reducer = (state = 'GO', action) => {
switch(action.type) {
case 'GO':
state = 'GO'
break;
case 'STOP':
state = 'STOP'
break;
case 'CAUTION':
state = 'CAUTION';
break;
}
return state;
}
接下来,该代码定义了 3 个操作对象,每个对应于一个状态,如清单 2 所示。
清单 2. 交通信号灯操作
1
2
3
4
5
6
7
8
9
10
11
const cautionAction = {
type: 'CAUTION'
};
const goAction = {
type: 'GO'
};
const stopAction = {
type: 'STOP'
}
最后,如清单 3 所示,应用程序分派操作,通过 Redux 存储的 getState() 方法获取当前状态的引用,并将该状态的值打印到控制台。
清单 3. 分配交通信号灯操作
1
2
3
4
5
6
7
8
9
10
// Dispatch actions....................................................
store.dispatch(stopAction);
console.log('State: ' + store.getState());
store.dispatch(cautionAction);
console.log('State: ' + store.getState());
store.dispatch(goAction);
console.log('State: ' + store.getState())
收藏
分享
评分
回复
引用
订阅
TOP
返回列表
电商论坛
Pine A64
资料下载
方案分享
FAQ
行业应用
消费电子
便携式设备
医疗电子
汽车电子
工业控制
热门技术
智能可穿戴
3D打印
智能家居
综合设计
示波器技术
存储器
电子制造
计算机和外设
软件开发
分立器件
传感器技术
无源元件
资料共享
PCB综合技术
综合技术交流
EDA
MCU 单片机技术
ST MCU
Freescale MCU
NXP MCU
新唐 MCU
MIPS
X86
ARM
PowerPC
DSP技术
嵌入式技术
FPGA/CPLD可编程逻辑
模拟电路
数字电路
富士通半导体FRAM 铁电存储器“免费样片”使用心得
电源与功率管理
LED技术
测试测量
通信技术
3G
无线技术
微波在线
综合交流区
职场驿站
活动专区
在线座谈交流区
紧缺人才培训课程交流区
意见和建议