跨框架探索:React Redux 和 Vuex 对比分析快速掌握React Redux

React Redux 和 Vuex 都是前端状态管理库,分别用于 React 和 Vue.js 框架。
redux运行过程图
在这里插入图片描述

它们都提供了一套规范的状态管理机制,帮助开发者更好地组织和管理应用状态。下面是它们的一些异同点:

相同点:

  1. 中心化状态管理:两者都提供了一个全局的存储中心,使得组件间状态共享变得简单。
  2. 响应式:状态变更时,依赖于这些状态的所有组件都会自动更新。
  3. 调试工具:React Redux 和 Vuex 都有专门的开发者工具,方便调试。
  4. 社区和生态:两者都有强大的社区支持,提供了大量的中间件和插件。

不同点:

  1. 设计理念
    • React Redux 遵循 Flux 架构,强调单一数据源和单向数据流。
    • Vuex 更倾向于 Vue.js 的响应式特性和组件化思想,提供了更灵活的状态变更方式。
  2. API 使用
    • React Redux 需要使用 connect 函数将组件连接到 Redux store,同时使用 mapStateToPropsmapDispatchToProps 来指定组件如何从 store 中读取状态和分发动作。
    • Vuex 使用 store 实例直接在组件中分发动作和获取状态,通过 this.$store 在 Vue 组件中访问。
  3. 状态变更方式
    • React Redux 通过 dispatch 方法发送一个动作(action)到 store,由 reducer 根据动作类型更新状态。
    • Vuex 提供了 commitdispatch 两个方法,commit 用于提交一个变更(mutation),而 dispatch 用于分发一个动作(action)。Vuex 的 mutation 必须是同步的,而 action 可以包含任意异步操作。
  4. 模块化
    • React Redux 通过 combineReducers 将多个 reducer 合并成一个根 reducer,从而实现模块化。
    • Vuex 允许将 store 分割成模块(module),每个模块拥有自己的 state、mutation、action 和 getter。
  5. 辅助函数和中间件
    • React Redux 常用 redux-thunk 等中间件来处理异步逻辑。
    • Vuex 自身就支持异步操作的处理,并且有 mapStatemapGettersmapActionsmapMutations 等辅助函数简化模板代码。
  6. 与框架的集成度
    • React Redux 更像是 React 生态系统的一部分,与 React 的 Context API 紧密集成。
    • Vuex 深度集成到 Vue.js 中,例如使用 Vue 的响应式系统来跟踪状态变化。
      为了快速掌握 React Redux,你可以遵循以下步骤:
  7. 理解 Redux 基础概念:熟悉 Redux 的三个核心概念:store、action 和 reducer。
  8. 学习 React Redux API:掌握 connectProvidermapStateToPropsmapDispatchToProps 的使用。
  9. 实践:通过小项目来实践 React Redux 的使用,例如一个简单的 TODO 应用。
  10. 了解异步处理:学习如何使用 redux-thunkredux-saga 等中间件处理异步逻辑。
  11. 阅读文档和社区资源:官方文档是学习的好地方,同时也可以查看社区提供的教程和最佳实践。

React Redux 和 Vuex 各有特点,理解它们的设计理念和 API 使用方式,可以帮助你更好地应用它们于实际项目中。

下面是 React Redux 和 Vuex 的简单示例代码,用于展示如何在各自的框架中管理状态。

在这里插入图片描述

React Redux 示例(class组件)

首先,我们定义一个简单的 Redux store,包括一个 reducer 和一个 action。

// Redux 的 reducer
const counterReducer = (state = { count: 0 }, action) => {
  switch (action.type) {
    case 'INCREMENT':
      return { count: state.count + 1 };
    case 'DECREMENT':
      return { count: state.count - 1 };
    default:
      return state;
  }
};
// Redux 的 action creator
const increment = () => {
  return { type: 'INCREMENT' };
};
const decrement = () => {
  return { type: 'DECREMENT' };
};
// 创建 Redux store
const store = Redux.createStore(counterReducer);

然后,我们创建一个 React 组件,并通过 connect 函数将其连接到 Redux store。

// React 组件
class Counter extends React.Component {
  render() {
    const { count, increment, decrement } = this.props;
    return (
      <div>
        <button onClick={increment}>+</button>
        <span>{count}</span>
        <button onClick={decrement}>-</button>
      </div>
    );
  }
}
// 将 Redux state 和 action 映射到组件的 props
const mapStateToProps = (state) => {
  return {
    count: state.count
  };
};
const mapDispatchToProps = (dispatch) => {
  return {
    increment: () => dispatch(increment()),
    decrement: () => dispatch(decrement())
  };
};
// 连接 React 组件和 Redux store
const ConnectedCounter = connect(mapStateToProps, mapDispatchToProps)(Counter);

最后,我们使用 Provider 组件将 store 传递给整个应用程序。

ReactDOM.render(
  <Provider store={store}>
    <ConnectedCounter />
  </Provider>,
  document.getElementById('root')
);

React Redux 示例(函数式组件)

通常使用 Hooks 来与 Redux 进行交互。下面是一个使用 React Redux 的函数式组件示例,它展示了如何使用 useSelectoruseDispatch Hooks 来读取 Redux store 中的状态和分发 actions。
首先,我们定义一个简单的 Redux store,包括一个 reducer 和一些 actions。

// Redux 的 reducer
const counterReducer = (state = { count: 0 }, action) => {
  switch (action.type) {
    case 'INCREMENT':
      return { count: state.count + 1 };
    case 'DECREMENT':
      return { count: state.count - 1 };
    default:
      return state;
  }
};
// Redux 的 action creator
const increment = () => {
  return { type: 'INCREMENT' };
};
const decrement = () => {
  return { type: 'DECREMENT' };
};
// 创建 Redux store
const store = Redux.createStore(counterReducer);

然后,我们创建一个函数式组件,并使用 useSelectoruseDispatch Hooks。

// React 函数式组件
const Counter = () => {
  // 使用 useSelector Hook 来访问 Redux store 中的状态
  const count = useSelector(state => state.count);
  // 使用 useDispatch Hook 来获取 dispatch 函数
  const dispatch = useDispatch();
  // 组件渲染的内容
  return (
    <div>
      <button onClick={() => dispatch(increment())}>+</button>
      <span>{count}</span>
      <button onClick={() => dispatch(decrement())}>-</button>
    </div>
  );
};

最后,我们使用 Provider 组件将 store 传递给整个应用程序。

import { Provider } from 'react-redux';
ReactDOM.render(
  <Provider store={store}>
    <Counter />
  </Provider>,
  document.getElementById('root')
);

在这个示例中,useSelector Hook 用于从 Redux store 中选择出我们需要的部分状态,而 useDispatch Hook 用于获取 dispatch 函数,以便我们可以在组件中分发 actions。这样的函数式组件更加简洁,并且易于理解和使用。

Vuex 示例

首先,我们定义一个 Vuex store,包括 state、mutation 和 action。

// Vuex 的 store
const store = new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    INCREMENT(state) {
      state.count++;
    },
    DECREMENT(state) {
      state.count--;
    }
  },
  actions: {
    increment({ commit }) {
      commit('INCREMENT');
    },
    decrement({ commit }) {
      commit('DECREMENT');
    }
  }
});

然后,我们创建一个 Vue 组件,并通过 this.$store 访问 Vuex store。

// Vue 组件
const Counter = {
  template: `
    <div>
      <button @click="increment">+</button>
      {{ count }}
      <button @click="decrement">-</button>
    </div>
  `,
  computed: {
    count() {
      return this.$store.state.count;
    }
  },
  methods: {
    increment() {
      this.$store.dispatch('increment');
    },
    decrement() {
      this.$store.dispatch('decrement');
    }
  }
};

最后,我们创建一个 Vue 实例,并将 Vuex store 作为选项传递。

new Vue({
  el: '#app',
  store,
  components: { Counter },
  template: `<Counter />`
});

这两个示例展示了如何在 React Redux 和 Vuex 中创建一个简单的计数器应用程序。在 React Redux 中,我们使用 connect 函数将 Redux store 的状态和分发动作映射到 React 组件的 props。而在 Vuex 中,我们直接在 Vue 组件中使用 this.$store 来访问状态和分发动作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/528895.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

环形链表 II - LeetCode 热题 26

大家好&#xff01;我是曾续缘&#x1f61b; 今天是《LeetCode 热题 100》系列 发车第 26 天 链表第 5 题 ❤️点赞 &#x1f44d; 收藏 ⭐再看&#xff0c;养成习惯 环形链表 II 给定一个链表的头节点 head &#xff0c;返回链表开始入环的第一个节点。 如果链表无环&#xf…

docker部署coredns服务器

创建文件夹 mkdir /coredns/config/添加一个CoreDNS配置文件 cat >/coredns/config/Corefile<<EOF.:53 {forward . 114.114.114.114:53log}EOF启动docker docker run -d --name coredns --restartalways \-v /coredns/config:/etc/coredns \-p 53:53/udp \regist…

HarmonyOS 开发-短视频切换实现案例

介绍 短视频切换在应用开发中是一种常见场景&#xff0c;上下滑动可以切换视频&#xff0c;十分方便。本模块基于Swiper组件和Video组件实现短视频切换功能。 效果图预览 使用说明 上下滑动可以切换视频。点击屏幕暂停视频&#xff0c;再次点击继续播放。 实现思路 使用Sw…

一文了解ERC404协议

一、ERC404基础讲解 1、什么是ERC404协议 ERC404协议是一种实验性的、混合的ERC20/ERC721实现的&#xff0c;具有原生流动性和碎片化的协议。即该协议可让NFT像代币一样进行拆分交易。是一个图币的互换协议。具有原生流动性和碎片化的协议。 这意味着通过 ERC404 协议&#xf…

混淆时,编译器优化导致通过反射赋值的类被清空问题

有几个反射赋值的类&#xff0c;之前一直是 keep 整个class的&#xff0c;现在要求对class的路径进行混淆。 当我启用混淆后&#xff0c;发现整个类的内容被清空了。 // 原始的类内容public class BaseLoadData {property("config_data1")public static String dat…

R语言数据可视化:ggplot2绘图系统

ggpolt2绘图系统被称为R语言中最高大上的绘图系统&#xff0c;使用ggplot2绘图系统绘图就像是在使用语法创造句子一样&#xff0c;把数据映射到几何客体的美学属性上。因此使用ggplot2绘图系统的核心函数ggplot来绘图必须具备三个条件&#xff0c;数据data&#xff0c;美学属性…

如何开始用 C++ 写一个光栅化渲染器?

光栅化渲染器是计算机图形学中最基础且广泛应用的一种渲染技术&#xff0c;它将三维模型转化为二维图像。下面我们将逐步介绍如何使用C语言从零开始构建一个简单的光栅化渲染器。 一、理解光栅化渲染原理 光栅化是一种将几何数据&#xff08;如点、线、三角形&#xff09;转换…

视频拍摄后如何用二维码分享?在线制作视频二维码的方法

现在很多人会将拍摄的视频内容用生成二维码的方式来分享给其他人&#xff0c;与以前使用微信、QQ、网盘等形式相比&#xff0c;二维码能够更加简单快捷的将视频传递给其他人查看&#xff0c;不需要下载缓存占用扫码者的内存&#xff0c;提供更好的用户体验效果。 视频转二维码…

大语言模型及提示工程在日志分析任务中的应用 | 顶会IWQoS23 ICPC24论文分享

本文是根据华为技术专家陶仕敏先生在2023 CCF国际AIOps挑战赛决赛暨“大模型时代的AIOps”研讨会闪电论文分享环节上的演讲整理成文。 BigLog&#xff1a;面向统一日志表示的无监督大规模预训练方法 BigLog: Unsupervised Large-scale Pre-training for a Unified Log Represen…

低代码平台适合谁用?业务岗能用它做什么?开发岗能用它做什么?一文讲清!

近期&#xff0c;低代码开发平台以其独特的魅力&#xff0c;迅速引发了大众的广泛关注。众多人士纷纷寻求了解各类低代码产品&#xff0c;以探究其功能与特点。 然而&#xff0c;有些人可能因一两款产品的体验不佳&#xff0c;便对整个低代码行业产生了偏见。但我要指出的是&am…

JS 表单验证

点击注册的时候&#xff0c;渲染出来&#xff0c;验证码是自动获取出来的 html&#xff1a; <div class"div1">用户名<input type"text" id"yhm"><span id"span1"></span><br>密码<input type"…

用AI作图,使用这个免费网站,快看我画的大鹏鸟和美女

还是大剑师兰特&#xff1a;曾是美国某知名大学计算机专业研究生&#xff0c;现为航空航海领域高级前端工程师&#xff1b;CSDN知名博主&#xff0c;GIS领域优质创作者&#xff0c;深耕openlayers、leaflet、mapbox、cesium&#xff0c;canvas&#xff0c;webgl&#xff0c;ech…

C语言面试题之判定字符是否唯一

判定字符是否唯一 实例要求 实现一个算法&#xff0c;确定一个字符串 s 的所有字符是否全都不同 实例分析 1、使用一个大小为 256 的bool数组 charSet 来记录字符是否出现过&#xff1b;2、遍历字符串时&#xff0c;如果字符已经在数组中标记过&#xff0c;则返回 false&a…

Linux、Docker、Brew、Nginx常用命令

Linux、Docker、Brew、Nginx常用命令 Linuxvi编辑器文件操作文件夹操作磁盘操作 DockerBrewNginx参考 Linux vi编辑器 Vi有三种模式。命令模式、输入模式、尾行模式&#xff0c;简单的关系如下&#xff1a; i -- 切换到输入模式&#xff0c;在光标当前位置开始输入文本。&a…

代码随想录算法训练营Day48|LC198 打家劫舍LC213 打家劫舍IILC337 打家劫舍III

一句话总结&#xff1a;前两题白给&#xff0c;第三题树形DP有点难。 原题链接&#xff1a;198 打家劫舍 滚动数组直接秒了。 class Solution {public int rob(int[] nums) {int n nums.length;int first 0, second nums[0];for (int i 2; i < n; i) {int tmp Math.m…

SysTick滴答定时器 - 延时函数

SysTick定时器 Systick定时器&#xff0c;是一个简单的定时器&#xff0c;对于CM3,CM4内核芯片&#xff0c;都有Systick定时器。Systick定时器常用来做延时&#xff0c;或者实时系统的心跳时钟。这样可以节省MCU资源&#xff0c;不用浪费一个定时器。比如UCOS中&#xff0c;分…

记录一次Ubuntu 22.04桌面版安装向日葵的过程

大概花了近一天的时间安装了WIN11和Ubuntu 22.04双系统&#xff0c;中间Ubuntu安装时出现了好几次失败&#xff0c;后来检查可能是下载的iso文件有问题&#xff0c;重新下载一次&#xff0c;刻录到U盘。安装才算成功。 最后的Ubuntu系统信息如下 接着安装向日葵的时候出错了&a…

visionOS 专门应用提交数大幅下降;Kimi 不断「吊打」国内各大厂 AI 模型丨 RTE 开发者日报 Vol.180

开发者朋友们大家好&#xff1a; 这里是 「RTE 开发者日报」&#xff0c;每天和大家一起看新闻、聊八卦。我们的社区编辑团队会整理分享 RTE &#xff08;Real Time Engagement&#xff09; 领域内「有话题的新闻」、「有态度的观点」、「有意思的数据」、「有思考的文章」、「…

【六 (3)机器学习-机器学习建模步骤/kaggle房价回归实战】

目录 文章导航一、确定问题和目标&#xff1a;1、业务需求分析&#xff1a;2、问题定义&#xff1a;3、目标设定&#xff1a;4、数据可行性评估&#xff1a;5、资源评估&#xff1a;6、风险评估&#xff1a; 二、数据收集&#xff1a;1、明确数据需求2、选择数据来源3、考虑数据…

显示LED屏驱动内置上电复位电路,2线串行接口-VK1640 SOP28 8×16点阵

产品品牌&#xff1a;永嘉微电/VINKA 产品型号&#xff1a;VK1640 封装形式&#xff1a;SOP2 概述 VK1640是一种数码管或点阵LED驱动控制专用芯片&#xff0c;内部集成有数据锁存器、LED 驱动等电路。SEG脚接LED阳极&#xff0c;GRID脚接LED阴极&#xff0c;可支持8SEGx16GR…