Redux入门

Redux入门

本文转载自:众成翻译

译者:miaoYu

链接:http://www.zcfy.cc/article/4728

原文:https://bumbu.github.io/simple-redux

本文尝试解释Redux是如何运作的。我们将用Redux创建一个小案列。如果你正在找靠谱的Redux文档,可以去看官方文档

什么是Redux

来自官方文档的描述:Redux是一个可预测的JavaScript状态容器。换句话说,Redux就是用来处理和管理应用的状态/数据。

如下:

更多图解 点这里_

现在我们来一步一步来解答上面的图代表什么意思。

State(状态)

任何应用都有一个状态。有些状态保存在数据库中,有些状态保存到不同的地方。在Redux中,状态存在一个单一的对象中。它知道哪个页面正打开着,它知道当前用户信息等等。状态可能是标准化,也可以是规范化的,所以当在不同的浏览器打开时,会渲染出相同的应用(同样的页面,同样的用户...)

让我们为计数应用定义我们的状态:

`var initialState = {counter: 0}`

render(渲染)

Redux和React.js一起用效果很好,但是不用react.js也可以。我们用原生JavaScript来把状态渲染到页面:

`<div>-</div>`
function render(state) {
  document.getElementById(‘counter‘).textContent = state.counter;
}

Actions

如果应用状态发生改变,那是因为有Actions触发了。他们可能是用户操作,也可能是异步操作,定时操作扥等等。我们将定义一个按钮来触发操作。

`&lt;button id="button"&gt;Increment&lt;/button&gt;`
`document.getElementById(‘button‘).addEventListener(‘click‘, incrementCounter)`

Store 和 reducer

Actions不会马上改变state。Redux的 store 处理这事:

var store = Redux.createStore(reducer, initialState)

function incrementCounter() {
  store.dispatch({
    type: ‘INCREMENT‘
  })
}

store保存当前的状态,以及对actions做出反应。当一个action被触发,传入当前的state和当前的action到reducer中,reducer返回新的state,state被更新:

function reducer(state, action) {
  if (action.type === ‘INCREMENT‘) {
    state = Object.assign({}, state, {counter: state.counter + 1})
  }
  return state
}

State 改变

当state改变,重新渲染:

store.subscribe(function() {
  render(store.getState())
})

一个React.js渲染器可以很好的处理这件事,只更新改变的部分,而不会去更新全部。

第一次渲染

如果action没有被触发就不会渲染,所以我们来触发第一次渲染:

`render(store.getState())`

最终代码

jsfiddle

// html
<div>-</div>
&lt;button id="button"&gt;Inc&lt;/button&gt;
// js
var initialState = {counter: 0}
var store = Redux.createStore(reducer, initialState)

function render(state) {
  document.getElementById(‘counter‘).textContent = state.counter;
}

document.getElementById(‘button‘).addEventListener(‘click‘, function() {
  incrementCounter()
})

function incrementCounter() {
  store.dispatch({
    type: ‘INCREMENT‘
  })
}

function reducer(state, action) {
  if (action.type === ‘INCREMENT‘) {
    state = Object.assign({}, state, {counter: state.counter + 1})
  }
  return state
}

store.subscribe(function() {
  render(store.getState())
})

// 渲染初始化的 state
render(store.getState())

与MobX比较

在Redux中,你可以控制任何事:actions, action的创建,状态更新等等。意味着每个应用程序都是可以预测的。但是导致了很多重复的代码。另一方面,MobX达到相同的效果,但隐藏了一些用户触发的actions,所以你可以写更少的代码。

当然,Redux更加成熟,以及支持一些新特性,比如服务器端渲染和一些很棒的开发工具。

> 原文:https://bumbu.github.io/simple-redux/

时间: 2024-10-05 04:56:12

Redux入门的相关文章

Redux 入门教程

Redux 入门教程(三):React-Redux 的用法([email protected]) Redux 入门教程(二):中间件与异步操作([email protected]) Redux 入门教程(一):基本用法([email protected])

redux 入门教程1

新手看网上一些redux文章,很容易被那些概念搞糊涂,本人照着官方例子打算写个系列新手教程,大家可以参考下,转载请注明出处 教程1即没有用到react,也没有用到npm这些东西,非常适合大家从本质上理解redux. 1.加载redux.js  <script src="https://npmcdn.com/[email protected]/dist/redux.min.js"></script> 2.html <div id="containe

redux入门二

在redux中用户的操作并不会直接导致view层的更新,而是view层发出actions通知出发store里的reducer从而来更新state. Action就像一个指挥者,告诉我们应该做哪些事,比如我要删除,reducer就会给我们提供'资源(就是上面说的数据)',真正的体力劳动者是reducer. 也就是说,action里面的每一种描述,比如新增啦,删除一个,删除全部啦,reducer都有一个对应的函数来处理数据.之后返回给你一个新的state. reducer 只是一个模式匹配的东西,真

Redux 入门教程(三):React-Redux 的用法

作者: 阮一峰 前两篇教程介绍了 Redux 的基本用法和异步操作,今天是最后一部分,介绍如何在 React 项目中使用 Redux. 为了方便使用,Redux 的作者封装了一个 React 专用的库 React-Redux,本文主要介绍它. 这个库是可以选用的.实际项目中,你应该权衡一下,是直接使用 Redux,还是使用 React-Redux.后者虽然提供了便利,但是需要掌握额外的 API,并且要遵守它的组件拆分规范. 一.UI 组件 React-Redux 将所有组件分成两大类:UI 组件

Redux入门之实现一个迷你版的Redux

Redux是一种数据架构模式,它可以用来管理应用的状态. 之前一直在做Angular的项目,没有使用到过Redux,对于Redux的使用场景和原理都不是很清楚,看资料时作者自己实现了一个Redux,在这里记录一下,加深对Redux原理的理解. 一.基本原理 首先,我们要明白的是: 状态的改变一定是有原因的,这个原因的表现叫作action. 有了action之后,状态不可能自己就改变,需要我们去操作它,这个操作就是reducer函数. 操作状态需要2个条件,之前的状态和触发操作的action,这个

react-redux入门教程(三)

Redux 入门教程(三):React-Redux 的用法 作者: 阮一峰 日期: 2016年9月21日 前两篇教程介绍了 Redux 的基本用法和异步操作,今天是最后一部分,介绍如何在 React 项目中使用 Redux. 为了方便使用,Redux 的作者封装了一个 React 专用的库 React-Redux,本文主要介绍它. 这个库是可以选用的.实际项目中,你应该权衡一下,是直接使用 Redux,还是使用 React-Redux.后者虽然提供了便利,但是需要掌握额外的 API,并且要遵守它

webpack+react+redux+es6

一.预备知识 node, npm, react, redux, es6, webpack 二.学习资源 ECMAScript 6入门 React和Redux的连接react-redux Redux 入门教程   redux middleware 详解   Redux研究 React 入门实例教程 webpack学习demo NPM 使用介绍 三.工程搭建 之前有写过 webpack+react+es6开发模式 ,文章里介绍了一些简单的配置,欢迎访问. 1.可以npm init, 创建一个新的工程

webpack+react+redux+es6开发模式

一.预备知识 node, npm, react, redux, es6, webpack 二.学习资源 ECMAScript 6入门 React和Redux的连接react-redux Redux 入门教程   redux middleware 详解   Redux研究 React 入门实例教程 webpack学习demo NPM 使用介绍 三.工程搭建 之前有写过 webpack+react+es6开发模式 ,文章里介绍了一些简单的配置,欢迎访问. 1.可以npm init, 创建一个新的工程

6周学习计划,攻克JavaScript难关(React/Redux/ES6 etc.)

6周学习计划,攻克JavaScript难关(React/Redux/ES6 etc.) 余博伦· 2 个月前 原文链接:A Study Plan To Cure JavaScript Fatigue 作者:Sacha Greif 和大家一样,最近我也看了Jose Aguinaga写的How it feels to learn JavaScript in 2016. 显然这篇文章击中了人们的痛处.它在Hacker News上排了不止一次第一.同样也是/r/javascript上最火的一篇,在Med