青少年编程与数学 02-006 前端开发框架VUE 22课题、状态管理

青少年编程与数学 02-006 前端开发框架VUE 22课题、状态管理

  • 一、状态管理
  • 二、Vuex
      • 1. 安装Vuex
      • 2. 创建Vuex Store
      • 3. 在Vue应用中使用Store
      • 4. 在组件中使用状态
      • 5. 模块化Store
  • 三、Vuex应用示例
      • 1. 创建项目
      • 2. 安装Vuex
      • 3. 设置Vuex Store
      • 4. 在主项目中使用Store
      • 5. 创建组件
      • 6. 更新App.vue
      • 7. 运行项目
  • 四、pinia
  • 五、Pinia 与 Vuex 的区别
  • 六、Pinia yiet
      • 步骤 1: 创建项目
      • 步骤 2: 安装依赖
      • 步骤 3: 设置Pinia
      • 步骤 4: 创建组件
      • 步骤 5: 在主应用中使用组件
      • 步骤 6: 运行项目
      • 步骤 7: 构建项目
      • 总结

课题摘要:本文介绍了Vue中的状态管理,重点讲解了Vuex和Pinia两种状态管理库。Vuex是Vue的官方状态管理库,适用于大型应用,它采用集中式存储管理应用状态,并确保状态以可预测的方式变化。文章详细阐述了Vuex的安装、创建Store、在Vue应用中使用Store、以及模块化Store的步骤。Pinia作为Vue 3的新一代状态管理库,以其轻量级、直观的API、TypeScript支持和模块化设计等特点,提供了一种更简洁的状态管理方案。文章还提供了使用Vuex和Pinia的示例代码,展示了如何在Vue项目中实现状态管理和组件间的状态共享。


一、状态管理

状态管理是软件工程中的一个概念,它涉及到在应用程序的不同部分之间跟踪、管理和同步状态(即数据)。在现代的前端开发中,尤其是在单页应用(SPA)中,状态管理尤为重要,因为它们通常需要处理复杂的用户界面和大量的交互。

以下是状态管理的一些关键点:

  1. 状态(State)

    • 状态是应用在任何给定时间点的信息集合,它可以包括用户界面的状态、应用程序的配置、用户数据等。
  2. 状态的不可变性(Immutability)

    • 在状态管理中,状态被视为不可变的,这意味着状态一旦被设置,就不能被直接改变。任何状态的改变都通过产生新的状态来实现。
  3. 状态的集中管理(Centralized State Management)

    • 集中管理状态意味着所有的状态都被存储在一个单一的地方(如Vuex、Redux等状态管理库),这有助于避免状态分散在组件树中,使得状态的跟踪和调试变得更加困难。
  4. 状态的可预测性(Predictability)

    • 状态管理的目标之一是使状态的变化可预测。这意味着状态的变化应该是可追踪和可重现的。
  5. 状态的响应性(Reactivity)

    • 在Vue等框架中,状态管理通常与响应式系统结合使用,这意味着当状态发生变化时,依赖这些状态的UI会自动更新。
  6. 状态管理库

    • 有许多库和框架提供了状态管理的解决方案,如Redux(与React一起使用)、Vuex(与Vue一起使用)、MobX等。
  7. 状态的生命周期(State Lifecycle)

    • 状态管理还涉及到状态的生命周期,包括状态的初始化、更新、删除等。
  8. 副作用(Side Effects)

    • 在状态管理中,副作用指的是那些不直接影响状态,但可能会引起外部变化的操作,如API调用、路由跳转等。这些副作用通常需要被管理,以确保状态的一致性和应用的稳定性。
  9. 模块化(Modularization)

    • 状态管理通常支持模块化,允许开发者将状态分割成更小的部分,每个部分管理自己的状态,这有助于保持代码的可维护性和可扩展性。

状态管理是构建大型、复杂前端应用的关键,它有助于提高应用的可维护性、可测试性和可扩展性。

二、Vuex

在Vue项目中实现状态管理,通常会使用Vuex作为状态管理库,尤其是对于大型应用。Vuex是Vue的官方状态管理库,它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。以下是在Vue项目中使用Vuex实现状态管理的基本步骤:

1. 安装Vuex

如果你的项目中还没有安装Vuex,可以通过npm或yarn来安装:

npm install vuex@next --save  # 对于Vue 3项目

2. 创建Vuex Store

在项目的 src 目录下创建一个 store 目录,并在其中创建 index.js 文件:

// src/store/index.js
import { createStore } from 'vuex';const store = createStore({state() {return {count: 0};},getters: {doubleCount(state) {return state.count * 2;}},mutations: {increment(state) {state.count++;}},actions: {increment(context) {context.commit('increment');}}
});export default store;

3. 在Vue应用中使用Store

src/main.js 中引入并使用store:

// src/main.js
import { createApp } from 'vue';
import App from './App.vue';
import store from './store';const app = createApp(App);app.use(store);app.mount('#app');

4. 在组件中使用状态

在Vue组件中,你可以通过mapStatemapGettersmapMutationsmapActions辅助函数来使用store中的状态和方法:

<template><div><p>{{ count }}</p><p>{{ doubleCount }}</p><button @click="increment">Increment</button></div>
</template><script>
import { mapState, mapGetters, mapActions } from 'vuex';export default {computed: {...mapState(['count']),...mapGetters(['doubleCount'])},methods: {...mapActions(['increment'])}
};
</script>

5. 模块化Store

对于大型应用,你可能需要将store分割成模块。在Vuex中,你可以使用模块来逻辑划分和管理状态:

// src/store/modules/counter.js
export default {namespaced: true,state() {return {count: 0};},getters: {doubleCount(state) {return state.count * 2;}},mutations: {increment(state) {state.count++;}},actions: {increment(context) {context.commit('increment');}}
};// src/store/index.js
import { createStore } from 'vuex';
import counter from './modules/counter';const store = createStore({modules: {counter}
});export default store;

在组件中使用模块化的状态和方法:

<script>
import { mapState, mapGetters, mapActions } from 'vuex';export default {computed: {...mapState('counter', ['count']),...mapGetters('counter', ['doubleCount'])},methods: {...mapActions('counter', ['increment'])}
};
</script>

通过这些步骤,你可以在Vue项目中实现状态管理,使得状态的维护和更新变得更加集中和有序。

三、Vuex应用示例

以下是一个使用Vue 3和Vite创建的项目的示例,它展示了如何使用Vue的组合式API(Composition API)和Vuex 4来实现状态管理。

1. 创建项目

假设你已经使用Vite创建了一个Vue 3项目:

npm create vite@latest my-vue-app -- --template vue
cd my-vue-app
npm install

2. 安装Vuex

在项目中安装Vuex:

npm install vuex@next

3. 设置Vuex Store

src 目录下创建一个 store 目录,并在其中创建 index.js 文件:

// src/store/index.js
import { createStore } from 'vuex';export default createStore({state() {return {count: 0,todos: [{ id: 1, text: 'Learn Vue', done: true },{ id: 2, text: 'Use Vuex', done: false },],};},getters: {doneTodos(state) {return state.todos.filter(todo => todo.done);},},mutations: {increment(state) {state.count++;},addTodo(state, todo) {state.todos.push(todo);},toggleTodo(state, todoId) {const todo = state.todos.find(todo => todo.id === todoId);if (todo) {todo.done = !todo.done;}},},actions: {increment(context) {context.commit('increment');},addTodo(context, todo) {context.commit('addTodo', todo);},toggleTodo(context, todoId) {context.commit('toggleTodo', todoId);},},
});

4. 在主项目中使用Store

src/main.js 中引入并使用store:

// src/main.js
import { createApp } from 'vue';
import App from './App.vue';
import store from './store';const app = createApp(App);app.use(store);app.mount('#app');

5. 创建组件

src 目录下创建 components 目录,并在其中创建 Counter.vueTodos.vue 组件:

<!-- src/components/Counter.vue -->
<template><div><button @click="decrement">-</button><span>{{ count }}</span><button @click="increment">+</button></div>
</template><script>
import { computed } from 'vue';
import { useStore } from 'vuex';export default {setup() {const store = useStore();const count = computed(() => store.state.count);function increment() {store.dispatch('increment');}function decrement() {store.commit('increment'); // 注意:这里直接提交mutation,因为不需要进行异步操作}return {count,increment,decrement,};},
};
</script>
<!-- src/components/Todos.vue -->
<template><div><ul><li v-for="todo in todos" :key="todo.id"><input type="checkbox" v-model="todo.done" @change="toggleTodo(todo.id)" /><span>{{ todo.text }}</span></li></ul><button @click="addTodo">Add Todo</button><div>Done Todos: {{ doneTodos.length }}</div></div>
</template><script>
import { computed } from 'vue';
import { useStore } from 'vuex';export default {setup() {const store = useStore();const todos = computed(() => store.state.todos);const doneTodos = computed(() => store.getters.doneTodos);function addTodo() {store.dispatch('addTodo', { id: Date.now(), text: 'New Todo', done: false });}function toggleTodo(todoId) {store.dispatch('toggleTodo', todoId);}return {todos,doneTodos,addTodo,toggleTodo,};},
};
</script>

6. 更新App.vue

src/App.vue 中使用这些组件:

<template><div id="app"><Counter /><Todos /></div>
</template><script>
import Counter from './components/Counter.vue';
import Todos from './components/Todos.vue';export default {name: 'App',components: {Counter,Todos,},
};
</script>

7. 运行项目

现在,你可以运行项目来查看状态管理的效果:

npm run dev

访问 http://localhost:3000 来查看应用,你将看到一个计数器和一个待办事项列表,它们的状态都由Vuex管理。

这个示例展示了如何在Vue 3项目中使用Vuex和组合式API来实现状态管理。你可以根据需要添加更多的状态和方法来扩展这个项目。

四、pinia

Pinia 是 Vue.js 的新一代状态管理库,专为 Vue 3 设计,并且也兼容 Vue 2。以下是 Pinia 的一些核心特点和简介:

  1. 轻量级:Pinia 是一个轻量级的状态管理库,体积非常小(大约1kb),几乎不会增加项目体积。

  2. 直观的 API:Pinia 的 API 设计简洁直观,类似于定义组件的方式定义 store,易于上手。

  3. TypeScript 支持:Pinia 提供了完整的 TypeScript 支持,使得在编写状态管理代码时能够获得更好的类型安全性和开发体验。

  4. 去除 Mutations:与 Vuex 不同,Pinia 没有 mutations,只有 state、getters 和 actions,actions 支持同步和异步操作。

  5. Vue Devtools 支持:Pinia 支持 Vue Devtools,提供更好的开发体验,可以在开发工具中查看和调试状态变化。

  6. 模块化设计:Pinia 鼓励将状态分割成多个 store,每个 store 都可以独立管理和维护,支持模块化和命名空间。

  7. 插件系统:Pinia 提供了一个插件系统,可以通过插件扩展功能,例如状态持久化、日志记录等。

  8. 状态持久化:通过 pinia-plugin-persistedstate 插件,可以轻松实现状态的持久化,将状态保存到浏览器的 localStorage 或 sessionStorage 中。

  9. 服务端渲染支持:Pinia 支持服务端渲染,可以在服务端渲染的 Vue 应用中方便地使用状态管理。

  10. 兼容性:虽然专为 Vue 3 设计,但也可以在 Vue 2 项目中使用(通过 pinia-compat)。

Pinia 的设计理念是将状态管理的复杂性降到最低,同时保持灵活性和可扩展性,使其成为 Vue 3 环境下的理想选择。

五、Pinia 与 Vuex 的区别

Pinia 作为 Vue 3 的新一代状态管理库,相较于 Vuex 有以下几个主要优势:

  1. 轻量级:Pinia 的体积非常小,压缩后大约只有 1KB,这使得它在性能上更加高效,尤其是在打包体积上更为精简。

  2. 简化的 API:Pinia 去除了 Vuex 中的 mutations,只保留了 stategettersactions,这简化了状态管理的流程,减少了样板代码。

  3. 组合式 API 风格:Pinia 与 Vue 3 的 Composition API 无缝集成,提供了更灵活的使用方式,使得状态的组织和复用更加简洁明了。

  4. 模块化设计:Pinia 提倡每个 Store 作为独立实体,自然支持模块化,不再需要像 Vuex 中通过 modules 配置来组织不同状态域,这简化了大型应用的状态管理架构。

  5. TypeScript 支持:Pinia 从一开始就对 TypeScript 提供了良好的支持,它的 API 设计考虑了 TypeScript 的使用,使得类型推断更加准确,减少了手动编写类型定义的需求。

  6. 性能优化:得益于其轻量级的设计和对 Vue 3 的深度优化,Pinia 在处理响应式数据时更为高效,特别是在使用 Composition API 时,性能表现得更加优异。

  7. 易用性提升:Pinia 的 API 设计围绕简洁和直观展开,降低了学习曲线,使得状态管理变得更加平易近人,即便是初学者也能快速上手并有效管理应用状态。

  8. 版本适应性:Pinia 专为 Vue 3 量身打造,充分利用 Vue 3 的最新特性和优化,为 Vue 3 应用提供最适配的状态管理方案。

  9. 支持插件功能:Pinia 支持插件来扩展自身功能,如状态持久化、日志记录等。

  10. 服务端渲染支持:Pinia 支持服务端渲染,可以在服务端渲染的 Vue 应用中方便地使用状态管理。

这些优势使得 Pinia 成为现代 Vue 开发的理想状态管理工具,尤其是在 Vue 3 项目中。

六、Pinia yiet

创建一个使用Vite、TypeScript、Vue 3组合式API(Composition API)和Pinia进行状态管理的完整项目示例,可以按照以下步骤进行:

步骤 1: 创建项目

首先,确保你已经安装了Node.js和npm/yarn。然后,使用Vite创建一个新的Vue 3项目,并选择TypeScript模板:

# 使用npm
npm create vite@latest my-vue-app --template vue-ts# 或者使用yarn
yarn create vite my-vue-app --template vue-ts

进入项目目录:

cd my-vue-app

步骤 2: 安装依赖

安装Pinia:

npm install pinia
# 或者
yarn add pinia

步骤 3: 设置Pinia

src目录下创建一个stores目录,并在其中创建一个Pinia store文件,例如useCounterStore.ts

// src/stores/counter.ts
import { defineStore } from 'pinia';export const useCounterStore = defineStore('counter', {state: () => ({count: 0,}),actions: {increment() {this.count++;},decrement() {this.count--;},},
});

步骤 4: 创建组件

src目录下创建一个新的组件,比如Counter.vue,并使用组合式API和Pinia store:

<template><div><button @click="decrement">-</button><span>{{ count }}</span><button @click="increment">+</button></div>
</template><script lang="ts">
import { defineComponent } from 'vue';
import { useCounterStore } from '@/stores/counter';export default defineComponent({name: 'Counter',setup() {const counterStore = useCounterStore();return {count: counterStore.count,increment: counterStore.increment,decrement: counterStore.decrement,};},
});
</script>

步骤 5: 在主应用中使用组件

编辑src/App.vue文件,引入并使用Counter组件:

<template><div id="app"><Counter /></div>
</template><script lang="ts">
import { defineComponent } from 'vue';
import Counter from './components/Counter.vue';export default defineComponent({name: 'App',components: {Counter,},
});
</script>

步骤 6: 运行项目

使用以下命令启动开发服务器:

npm run dev
# 或者
yarn dev

现在,你应该能够访问http://localhost:3000看到你的应用。

步骤 7: 构建项目

当你准备好将项目部署到生产环境时,运行以下命令:

npm run build
# 或者
yarn build

这将构建你的应用,并生成可以在生产环境中部署的文件。

总结

这个简单的项目示例展示了如何使用Vite、Vue 3、TypeScript和Pinia来创建一个基本的Web应用。你可以根据需要添加更多的组件、路由、API调用等。Pinia 提供了一种简洁直观的方式来管理应用状态,使得代码更加模块化和可重用。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

代码随想录算法训练营第 4 天(链表 2)| 24. 两两交换链表中的节点19.删除链表的倒数第N个节点 -

一、24. 两两交换链表中的节点 题目&#xff1a;24. 两两交换链表中的节点 - 力扣&#xff08;LeetCode&#xff09; 视频&#xff1a;帮你把链表细节学清楚&#xff01; | LeetCode&#xff1a;24. 两两交换链表中的节点_哔哩哔哩_bilibili 讲解&#xff1a;代码随想录 dummy-…

pycharm-pyspark 环境安装

1、环境准备&#xff1a;java、scala、pyspark、python-anaconda、pycharm vi ~/.bash_profile export SCALA_HOME/Users/xunyongsun/Documents/scala-2.13.0 export PATH P A T H : PATH: PATH:SCALA_HOME/bin export SPARK_HOME/Users/xunyongsun/Documents/spark-3.5.4-bin…

【大模型入门指南 07】量化技术浅析

【大模型入门指南】系列文章&#xff1a; 【大模型入门指南 01】深度学习入门【大模型入门指南 02】LLM大模型基础知识【大模型入门指南 03】提示词工程【大模型入门指南 04】Transformer结构【大模型入门指南 05】LLM技术选型【大模型入门指南 06】LLM数据预处理【大模型入门…

3DGabor滤波器实现人脸特征提取

import cv2 import numpy as np# 定义 Gabor 滤波器的参数 kSize 31 # 滤波器核的大小 g_sigma 3.0 # 高斯包络的标准差 g_theta np.pi / 4 # Gabor 函数的方向 g_lambda 10.0 # 正弦波的波长 g_gamma 0.5 # 空间纵横比 g_psi np.pi / 2 # 相位偏移# 生成 Gabor 滤…

【Linux】4.Linux常见指令以及权限理解(2)

文章目录 3. Linux指令3.1 ls指令和rm指令补充3.2 man指令&#xff08;重要&#xff09;3.3cp指令&#xff08;重要&#xff09;输出重定向3.3.1ubuntu20.04如何安装tree 3.4 mv指令&#xff08;重要&#xff09;mv指令更改文件名mv指令更改目录名 如何看待指令指令的重命名3.5…

Vue3初学之Element-plus

用于快速的上手开发&#xff0c;以做项目为导向&#xff0c;所以借用element-plus插件 发现淘宝的镜像有时候也是很慢的&#xff0c;还可以换个 npm config set registry https://registry.npmmirror.com 安装element-plus npm install element-plus --save 查看安装是否成…

实用操作系统学习笔记

第1章 操作系统概述 操作系统基本概念 【基础知识】 操作系统&#xff1a;控制和管理整个计算机系统的硬件和软件资源&#xff0c;合理地组织、调度计算机的工作与资源的分配&#xff0c;进而为用户和其他软件提供方便接口与环境的程序集合。操作系统是计算机系统中最基本的…

k8s部署rocketmq踩坑笔记

给团队部署一个rocketmq4.8.0. k8s上部署的broker&#xff0c;注册到nameserver上是自己的pod ip&#xff0c;导致本机连接到的broker的pod ip&#xff0c;这个ip k8s集群外的机器是无法联通的。 nameserver上注册的是这个pod ipv4 尝试将broker的配置brokerIP1修改为注册到na…

UI自动化测试保姆级教程①

欢迎来到阿妮莫的学习小屋慢也好&#xff0c;步子小也好&#xff0c;在往前走就好 目录 自动化测试 简介 作用 分类 优缺点 优点 缺点(误区) UI自动化测试 自动化测试使用场景 自动化测试实现时间 Selenium框架 特点 Web自动化测试环境部署 Selenium包安装 浏览…

【2024年华为OD机试】 (A卷,100分)- 总最快检测效率(Java JS PythonC/C++)

一、问题描述 题目描述 在系统、网络均正常的情况下组织核酸采样员和志愿者对人群进行核酸检测筛查。 每名采样员的效率不同&#xff0c;采样效率为 N 人/小时。由于外界变化&#xff0c;采样员的效率会以 M 人/小时为粒度发生变化&#xff0c;M 为采样效率浮动粒度&#xf…

离线录制激光雷达数据进行建图

目前有一个2D激光雷达&#xff0c;自己控制小车运行一段时间&#xff0c;离线获取到激光雷达数据后运行如下代码进行离线建图。 roslaunch cartographer_ros demo_revo_lds.launch bag_filename:/home/firefly/AutoCar/data/rplidar_s2/2025-01-08-02-08-33.bag实际效果如下 d…

蓝桥杯嵌入式速通(1)

1.工程准备 创建一文件夹存放自己的代码&#xff0c;并在mdk中include上文件夹地址 把所有自身代码的头文件都放在headfile头文件中&#xff0c;之后只需要在新的文件中引用headfile即可 headfile中先提前可加入 #include "stdio.h" #include "string.h"…

QT跨平台应用程序开发框架(1)—— 环境搭建

目录 一&#xff0c;关于QT 二&#xff0c;关于应用程序框架 三&#xff0c;环境搭建 3.1 预备 3.2 下载Qt SDK 3.3 安装Qt SDK 3.4 配置环境变量 3.5 认识一些重要工具 四&#xff0c;Qt Creator 的基本使用 4.1 创建项目 4.2 代码解释 一&#xff0c;关于QT 互联网…

Open FPV VTX开源之第一次出图

Open FPV VTX开源之第一次出图 1. 源由2. 连线2.1 飞控2.2 调试 3. serial3.1 启动log - uboot3.2 登录版本 - linux3.3 获取有线IP 4. ssh - linux5. PixelPilot出图6. 总结7. 参考资料 1. 源由 在《Open FPV VTX开源之硬件规格及组成》章节中&#xff0c;已经基本介绍了产品…

基于高斯混合模型的数据分析及其延伸应用(具体代码分析)

一、代码分析 &#xff08;一&#xff09;清除工作区和命令行窗口 clear; clc;clear;&#xff1a;该命令用于清除 MATLAB 工作区中的所有变量&#xff0c;确保代码运行环境的清洁&#xff0c;避免之前遗留的变量对当前代码运行产生干扰。例如&#xff0c;如果之前运行的代码中…

PostgreSQL技术内幕22:vacuum full 和 vacuum

文章目录 0.简介1.概念及使用方式2.工作原理2.1 主要功能2.2 清理流程2.3 防止事务id环绕说明 3.使用建议 0.简介 在之前介绍MVCC文章中介绍过常见的MVCC实现的两种方式&#xff0c;一种是将旧数据放到回滚段&#xff0c;一种是直接生成一条新数据&#xff08;对于删除是不删除…

【面试】程序员 简历

一、简历整体结构 完整简历包含基本信息、教育背景、求职意向、工作经历、职业技能、项目经历、个人优势和个人荣誉八个部分。编写时&#xff0c;前几部分在保证真实的基础上可适当美化&#xff1b;个人优势和荣誉描述要突出难点亮点且避免夸张&#xff0c;可写入如马拉松参赛、…

WebGIS在应急灾害中对村庄、风景区、机场的影响范围应用-以日喀则市定日县地震为例

目录 前言 一、关于影响范围 1、震中距离5公里 2、震中20公里范围 3、20到80公里范围 二、空间查询知识 1、相关数据介绍 2、空间数据查询 三、前后端数据查询以及web可视化实现 1、后台API实现 2、WebGIS前端实现 四、Web成果展示 1、空间位置分析 2、包含风景区…

【UE5 C++课程系列笔记】27——多线程基础——ControlFlow插件的基本使用

目录 步骤 一、搭建基本同步框架 二、添加委托 三、添加蓝图互动框架 四、修改为异步框架 完整代码 通过一个游戏初始化流程的示例来介绍“ControlFlows”的基本使用。 步骤 一、搭建基本同步框架 1. 勾选“ControlFlows”插件 2. 新建一个空白C类&#xff0c;这里…

JavaEE之定时器及自我实现

在生活当中&#xff0c;有很多事情&#xff0c;我们不是立马就去做&#xff0c;而是在规定了时间之后&#xff0c;在到该时间时&#xff0c;再去执行&#xff0c;比如&#xff1a;闹钟、定时关机等等&#xff0c;在程序的世界中&#xff0c;有些代码也不是立刻执行&#xff0c;…