美文网首页
Redux 的前期知识储备

Redux 的前期知识储备

作者: 婆娘漂亮生活安逸 | 来源:发表于2021-12-12 15:59 被阅读0次

写一个大背景吧:

我为什么会去学习这个 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 的前期知识储备已经结束。初次接触,肯定还是会很混乱。个人一直很想整理一篇实战部分的练习,但是无奈自己太懒惰了,以及不懂咋整理,就先这样搁置着了... 【下次一定???】

相关文章

网友评论

      本文标题:Redux 的前期知识储备

      本文链接:https://www.haomeiwen.com/subject/gnxqtrtx.html