Redux 的前期知识储备

写一个大背景吧:

我为什么会去学习这个 Redux ?或许是因为我在使用 React hooks 中的 useReducer 时突然被刺激到了吧~的确仿照官网 demo,都可以用上这些 API,但我却从来不理解我为什么要去用?何时去用?我想着,是时候去学习了 Redux 了吧~

好了~开始记录学习过程吧~

相关文档


Redux 介绍


1. 理解它存在的意义


比如有个页面组件树类似这个样子,一个层级特别深的 O 组件,更改后要去同步更改 A 组件。在传统的 React 中,将 props 层层传递,似乎可以解决问题~那么继续假设,随着业务增加,组件树变得日益壮大,组件之间的联系变得更加紧密,某一天你会突然发现,自己似乎已经不清楚组件之间的 state 是如何变化更新的。而你也无法预料到,修改这个组件的 state 之后,下一刻,别的地方又会发生什么?Redux 就是为了解决这个问题的,它试图让 state 的变化变得可预测。

2. 什么时候使用呢?

那么这里我直接引入官方文档的这篇 when-should-i-use-redux,原文是英文的,所以我稍微翻译了一下;大体是以下几个情况:

  • 在 App 中,有许多应用页面的 state 需要在多处使用。
  • App 中的 state 频繁需要更新。
  • 更新 state 的逻辑很复杂。
  • App 具有中等或大型的代码库,并且是多人开发的。
  • 你需要知道 state 随着时间变化是如何在更新的。

然后就可以自主选择是否真正需要去使用 Redux 啦~如果你只是想多学一门技术,当然也是可以哒~



Redux 三大原则


  • 单一数据源
    整个应用的 state 被储存在一棵 object tree 中,并且这个 object tree 只存在于唯一一个 store 中。

  • State 是只读的
    唯一改变 state 的方法就是触发 action,action 是一个用于描述已发生事件的普通对象。

  • 使用纯函数来执行修改
    为了描述 action 如何改变 state tree ,你需要编写 reducers



Redux 工作流程图


对于这张工作流程图,我在网上参考了很多,最后这种展示我认为是比较好理解的。或许一开始,还是会觉着陌生,但是随着学习的深入,就会越来越理解。


简单解释一下吧:
对于页面上的组件,需要进行更新时。我们需要主动去发起一个 action,调用 dispatch(action),来通知到 Store。Store 自动会去触发 reducer,根据之前的 state 和传入的 action,进行相关处理后,就会返回一个新的 state。而组件呢,就会根据最新的 getState()进行页面展示。



Redux 核心介绍


1. Action

本质是一个 JS 的对象,类似 {type: 'Add'}。其中 type 属性是必须的,它定义了当前的操作的类型,例如是添加,修改等等。除了 type 字段呢,其它的字段结构,可以由自己决定。
这里呢,我拿添加一个 Todo 进行举例:

  // define action type
  const ADD_TODO = 'ADD_TODO';

  // define action creator function
  const addTodo = (text) => {
    return {
      type: ADD_TODO,
      text
    }
  }

  // trigger by clicking button
  const clickAddButton = () => {
    const action = addTodo('add the first todo')
    dispatch(action)
  }

是不是很简单,其实主要的就是那一句话dispatch(action),其余的代码只是提了一个常量和封了一个方法而已。

2. Reducer

首先明确一点,它是一个纯函数。它接收旧的 state 和 action,返回新的 state。形如 (prevState, action) => newState

纯函数定义:
1. 如果函数的调用参数相同,则永远返回相同的结果。 它不依赖于程序执行期间函数外部任何状态或数据的变化,必须只依赖于其输入参数。
2. 该函数不会产生任何可观察的副作用,例如网络请求,输入和输出设备或数据突变(mutation)。

在上一步中,用户发起了添加一个 todo 操作之后,redux 会自动去调用这个 reducer 方法,它通常长这样哦:

  // define initial state
  const initialState = { 
      todos: []
  }
  
  /* @params 
   * state: get previous state here
   * action: dispatch params, defined by user
  */
  function reducer(state = initialState, action) {
   switch (action.type) {
     case ADD_TODO:
       return Object.assign({}, state, {
         todos: [
           ...state.todos,
           {
             text: action.text,
             completed: false
           }
         ]
       })
     default:
       return state
   }
 }


3. Store

再次强调一下 Redux 应用只有一个单一的 store。它有以下职责:

通常创建一个 store 非常的简单方便;

  import { createStore } from 'redux'
  // reducer is defined last step
  const store = createStore(reducer)




目前为止,我想说的一些关于 redux 的前期知识储备已经结束。初次接触,肯定还是会很混乱。个人一直很想整理一篇实战部分的练习,但是无奈自己太懒惰了,以及不懂咋整理,就先这样搁置着了... 【下次一定???】

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350

推荐阅读更多精彩内容