从 Flux 到 Redux 后,我学到的

从 Flux 到 Redux 后,我学到的

在前端开发中,管理状态一直是一个重要的议题。Flux 和 Redux 是两种非常流行的 JavaScript 状态管理库。它们可以帮助我们轻松地跟踪和管理应用程序状态,使我们可以轻松地编写可维护的应用程序。今天,我将分享我从 Flux 到 Redux 过程中的一些心得体会,并提供一些示例代码以帮助您更好地理解这些概念。

Flux

Flux 是一种管理状态的体系结构,Web 开发人员可以使用它来更新应用程序的状态并通知相关 UI 组件进行相应的更新。Flux 是单向数据流的,这意味着唯一的数据来源是存储库(store),它将所有的应用程序状态保存在一个地方,并允许我们通过发送行动(action)来更新它。这种模式有助于强制我们按照某个顺序进行代码的处理,并减少不必要的副作用。下面是一个简单的 Flux 应用程序示例:

-- ---------
----- ------------ - -
  ---- ------
  --------- ----------
--

-- -------
----- -------------- - -
  ---- -- -- --
    ----- ----------------
  ---
  --------- -- -- --
    ----- ---------------------
  --
--

-- -----
----- ------------ - ------------------ - -- ------- -- -
  ------ ------------- -
    ---- -----------------
      ------ ----- - --
    ---- ----------------------
      ------ ----- - --
    --------
      ------ ------
  -
---

-- ---------
----- ------- ------- --------------- -
  ------------------ -
    -------------
    ---------- - -
      -------- -----------------------
    --
  -
  ------------------- -
    ---------------- - ------------------------- -- -
      --------------- -------- ----------------------- ---
    ---
  -
  ---------------------- -
    -------------------
  -
  -------- -
    ------ -
      -----
        -----------------------------
        ------- ----------- -- ---------------------------------------------
          ---
        ---------
        ------- ----------- -- --------------------------------------------------
          --------
        ---------
      ------
    --
  -
-

------------------------ --- ---------------------------------

上述代码示例使用了 createStore 函数创建了一个存储库(store),它将应用程序状态保存在一个地方。在组件内部,我们使用 unsubscribe 函数来取消订阅订阅后在更新过程中执行的 store.subscribe 函数。此代码示例演示了如何将动作(action)分发给存储库,并将对象传递给它来更新应用程序的状态。这是一个简单但有效的 Flux 状态管理器示例。

Redux

在 Flux 的基础上,Redux 是一个强化版状态管理库。Redux 解决了一些 Flux 模式的问题并引入了一些新的特性:例如,Redux 提供了时间旅行调试功能,可以让我们查看应用程序状态的历史记录,并回滚到先前的状态。Redux 本质上是一个 flux 模式,它是基于单一的应用程序状态对象来管理状态的,它的状态管理模式非常直接。这是一个 Redux 应用程序示例:

-- ---------
----- ------------ - -
  ---- ------
  --------- ----------
--

-- -------
----- -------------- - -
  ---- -- -- --
    ----- ----------------
  ---
  --------- -- -- --
    ----- ---------------------
  --
--

-- --------
----- --------------- - ------ - -- ------- -- -
  ------ ------------- -
    ---- -----------------
      ------ ----- - --
    ---- ----------------------
      ------ ----- - --
    --------
      ------ ------
  -
--

-- -----
----- ----- - -----------------------------

-- ---------
----- ------- ------- --------------- -
  -------------------- -
    ---------------- - ------------------ -- -
      -------------------
    ---
  -
  ---------------------- -
    -------------------
  -
  -------- -
    ------ -
      -----
        ---------------------------
        ------- ----------- -- --------------------------------------------------
        ------- ----------- -- -------------------------------------------
          --------
        ---------
      ------
    --
  -
-

------------------------ --- ---------------------------------

上述代码示例介绍了 Redux 应用程序的结构,其中 store 由 reducer 处理函数组成,这是负责在应用程序状态更改过程中执行状态转换的函数。在组件中,我们使用 subscribe 函数来订阅存储库,并在回调中强制更新,这使得在更改存储库中的状态时,组件会自动更新。

从 Flux 到 Redux 的过渡

理解 Flux 模式和 Redux 框架的主要区别是十分重要的,因为它们之间有很多的相似性,但是 Redux 它提供了很多更鲜明的优点,使得应用开发更加的高效。在成为 Redux 的高手之前,您必须理解单向流动和状态不变的重要性。此外,我还发现使用 ES6 和函数式编程技术可以让代码更简洁、可读性更强。最后,在学习 Redux 中的一些工具时,比如 middleware、action creators 和 combineReducers,我发现这些工具可以提高生产力,并帮助您更好地组织代码。

总结

Flux 和 Redux 都是优秀的状态管理库,它们可以帮助我们管理应用程序中的状态。使用 Redux 在实际项目中的时候除了会用到其提供的状态管理的方案,我们还需要时刻考虑到其提议下的思想,如单向数据流、不可变数据、纯函数等等这些概念。在应用 Redux 的过程中,请确保您已经理解了核心概念,并使用设计的最佳实践。您可以通过尝试一个 Flux 或 Redux 应用程序,以便更好地了解这些概念和模式,并学习如何使用它们来管理 Web 应用程序中的状态。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/64ace8a248841e98948f9ac9


猜你喜欢

  • 网络请求中使用 ECMAScript 2020 新特性: Promise.allSettled()

    近年来,前端开发人员在工作中越来越需要学习和掌握新的 ECMAScript(也称 JavaScript)标准。ECMAScript 2020(ES2020)是最新的 JavaScript 标准,带来了...

    1 年前
  • Mongoose,一款优雅的 MongoDB 对象模型

    Mongoose,一款优雅的 MongoDB 对象模型 将MongoDB作为数据库来存储数据,可以带来许多方便。但是在前端类开发中,使用MongoDB很容易遇到不同的问题,例如数据的不一致,难以常规查...

    1 年前
  • 在 Promise.all 中如何忽略某些请求的响应结果

    前言 在实际开发中,经常会有需要同时处理多个请求的情况。为了实现更高效的并发处理,可以使用 Promise.all 方法。Promise.all 方法接收一个数组参数,数组中的每个元素都是一个 Pro...

    1 年前
  • Hapi 框架中使用 vision 插件渲染视图:详细教程

    标题:Hapi 框架中使用 vision 插件渲染视图:详细教程 在前端开发中,我们经常需要将后台数据渲染到网页上展示给用户,这时候就需要使用视图引擎来进行页面渲染。

    1 年前
  • Angular Bash 高级用法

    在 Angular 开发中,使用 Bash 脚本可以自动化完成许多任务,如自动测试、构建等。本文将介绍一些 Angular Bash 高级用法,帮助开发者更好地进行自动化开发。

    1 年前
  • Redux 以及中间件的使用

    什么是 Redux Redux 是一种状态管理模式,它可以让前端开发更加可预测、可控。它是 React 生态中最流行的状态管理库之一,但它并不限于 React,可以与 Angular、Vue 等框架集...

    1 年前
  • Headless CMS 如何支持多用户协作和编辑

    随着互联网的快速发展,越来越多的网站和应用需要管理和展示大量的内容,而传统的 CMS 由于其繁琐的后端管理界面,日益被 Headless CMS 所代替。Headless CMS 不仅具有前端友好的管...

    1 年前
  • MongoDB 如何解决并发性能低的问题

    背景 随着互联网的不断发展,数据量越来越大,访问量越来越高,对于数据库的并发性能提出了更高的要求。传统关系型数据库在高并发访问时性能下降明显,而非关系型数据库 MongoDB 却可以轻松应对高并发。

    1 年前
  • GraphQL schema 实现数据库 SQL 注入方案

    前言 GraphQL 作为一种新型的 Web API 技术,本质上是一种查询语言,其语言特性使得 GraphQL API 可以轻松地满足前端应用程序的订阅、查询、过滤、分页和排序需求。

    1 年前
  • Performance Optimization 技术和方法的综述

    在前端开发中,性能优化是一个非常重要的问题。随着前端技术的不断发展,网站的各种功能越来越复杂,需要大量的脚本和样式表来实现。这就导致了页面加载的时间变长,影响了用户的体验。

    1 年前
  • 如何使用 Web Components 实现异步数据加载

    Web Components 是一种用于构建可重用组件的 Web 标准,它提供了一种简单的方法来将复杂的应用程序拆分为更小、可维护的部分。通过使用 Web Components,我们可以轻松地创建自定...

    1 年前
  • 使用 Socket.io 和 React.js 构建实时在线聊天室

    实时在线聊天室已经成为许多应用程序的标准组成部分,例如在线游戏、选举投票、音乐比赛等。即时通讯技术可以用来捕捉一系列事件,从而让用户更快地与其他人沟通。 在本文中,我们将学习如何使用 Socket.i...

    1 年前
  • 使用 React Router 实现 SPA 应用时如何防止路由跳转时页面抖动?

    随着前端技术的发展,单页面应用(SPA)越来越流行,而 React Router 是用于构建 SPA 的常用库之一。然而,对于使用 React Router 实现的 SPA 应用,我们常常会遇到一个问...

    1 年前
  • 为什么我要选择 Tailwind CSS

    什么是 Tailwind CSS Tailwind CSS 是一种用于构建现代、可定制且高效的用户界面的实用工具集。它是一个 CSS 框架,但与 Bootstrap、Material Design 等...

    1 年前
  • 如何使用 Objective-C 与 RESTful API 构建 iOS 应用

    在构建 iOS 应用时,使用 Objective-C 与 RESTful API 是一种非常流行的方式。这种方式能够轻松实现数据的传输,而且客户端与服务器之间的通信也变得更加简单有效。

    1 年前
  • 使用 Deno 构建 GraphQL API

    什么是 Deno Deno 是一个安全的运行时环境,可以用来运行 JavaScript 和 TypeScript。它与 Node.js 相似,但有许多不同之处,例如它不需要使用 npm 进行包管理,而...

    1 年前
  • 解决 Cypress 在 IE 浏览器中无法运行的问题

    Cypress 是一个现代的、著名的前端测试工具。它非常流行、易于使用,能够方便地进行交互式 UI 测试。但是,它在 IE 浏览器中无法运行,这给前端开发人员带来了很大的麻烦,因为 IE 浏览器仍然是...

    1 年前
  • 网页开发之响应式设计

    随着移动设备的普及,越来越多的用户选择使用手机、平板电脑等移动设备浏览网页。这给互联网技术带来了新的挑战,如何让网页能够兼容各种屏幕大小,以实现最佳的用户体验呢?这就需要用到响应式设计。

    1 年前
  • 在 ECMAScript 2017 中使用 Proxy 构造函数进行对象代理

    随着现代前端开发的不断发展,JavaScript 作为一门动态语言和脚本语言,也在不断地创新和进化。其中,ECMAScript 2017 中引入了 Proxy 构造函数,它可以用于创建一个代理对象,从...

    1 年前
  • 如何使用 Express.js 处理 XML 数据

    在前端开发中,我们经常需要处理各种种类的数据,其中包括 XML 数据。XML 是一种数据格式,用于描述和传输数据,而 Express.js 则是一个使用 Node.js 构建的 Web 开发框架。

    1 年前

相关推荐

    暂无文章