n the previous lessons, we used this tool to up level variable to refer to the Redux chore. The components that access this chore, such as the container components, read this straight from it, subscribe to this chore, and dispatch actions on this cho…
Previously, we wrote the Provider component by ourself: class Provider extends Component { getChildContext() { return { store: this.props.store }; } render() { return this.props.children; } } Provider.childContextTypes = { store: React.PropTypes.obje…
We have to write a lot of boiler plate code to pass this chore down as a prop. But there is another way, using the advanced React feature called context. const TodoApp = ({ store }) => ( <div> <AddTodo store={store} /> <VisibleTodoList s…
用了几个月的redux,现在回过来总结一下. 刚开始用的时候遇到一个比较大的疑问,就是如何设计redux的store中的state树,这应该是我在使用redux中最大的一个疑问,阻挡了我前进的脚步,当时查阅了许多博客和官方文档,还询问了许多做react的同学,基本上讲的都不是很清楚,可能本身理解的就有问题或者是表达能力有限.我这里给大家用非常通俗易懂的方式说一说我的疑问,以及我是如何解决的. 当初主要的疑问是: 1.state树是按照页面划分 2.还是按照数据库中的表(users,events这…
Store Store 就是用来维持应用所有的 state 树 的一个对象. 改变 store 内 state 的惟一途径是对它 dispatch 一个action. Store 不是类.它只是有几个方法的对象. 要创建它,只需要把根部的 reducing 函数 传递给createStore. Flux 用户使用注意 如果你以前使用 Flux,那么你只需要注意一个重要的区别.Redux 没有 Dispatcher 且不支持多个 store.相反,只有一个单一的 store 和一个根级的 redu…
组件间传值联动是令人头疼的问题,尤其是一个组件影响多个其他组件状态变化的时候,常常需要一级一级与父组件传值,与父组件的兄弟组件传值等等, 如何化繁为简地处理‘牵一发动全身’的清理就是将所有组件的state中的值,用redux数据框架store统一记录管理. ReactComponents(组件)通过ActionCreators告诉Store要获取/更改哪个值,Store通过查询Reducer后,更新Reducer的值再将更新后的值传递给ReactCompnents 保持组件与Store中的存储数…
已经快一年没有碰过 React 全家桶了,最近换了个项目组要用到 React 技术栈,所以最近又复习了一下:捡起旧知识的同时又有了一些新的收获,在这里作文以记之. 在阅读文章之前,最好已经知道如何使用 Redux(不是 React-Redux). 一.准备环境 为了更好的解读源码,我们可以把源码拷贝到本地,然后搭建一个开发环境.Redux 的使用不依赖于 React,所以你完全可以在一个极为简单的 JavaScript 项目中使用它.这里不再赘述开发环境的搭建过程,需要的同学可以直接拷贝我的代码…
今天,我们通过解读官方示例代码(counter)的方式来学习react+redux. 例子 这个例子是官方的例子,计数器程序.前两个按钮是加减,第三个是如果当前数字是奇数则加一,第四个按钮是异步加一(延迟一秒). 源代码:https://github.com/lewis617/react-redux-tutorial/tree/master/redux-examples/counter 组件 components/Counter.js import React, { Component, Pro…
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 20.0px Helvetica } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Helvetica } p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 11.0px Helvetica; min-height: 13.0px } span.s1 { } span.Apple-tab-span { w…
Flux 架构已然让人觉得有些迷惑,而比 Flux 更让人摸不着头脑的是 Flux 与 Redux 的区别.Redux 是一个基于 Flux 思想的新架构方式,本文将探讨它们的区别. 如果你还没有看过这篇关于 Flux 的文章(译者注:也可以参考这篇),你应该先阅读一下. 为什么要改变 Flux? Redux 解决的问题和 Flux 一样,但 Redux 能做的还有更多. 和 Flux 一样,Redux 让应用的状态变化变得更加可预测.如果你想改变应用的状态,就必须 dispatch 一个 ac…