vue之vuex的使用及举例
Vuex是专门为Vue.js设计的集中式状态管理架构,它允许你将所有的组件共享状态存储在一个单独的地方,即“store”,并以相应的规则保证状态以一种可预测的方式发生变化。以下是Vuex的基本使用方法:
一、安装Vuex
对于Vue 2项目,推荐使用与Vue 2兼容的Vuex 3版本。可以通过npm或yarn进行安装:
bash复制代码
npm install vuex@3 --save | |
# 或者 | |
yarn add vuex@3 --save |
对于Vue 3项目,可以直接安装最新版本的Vuex:
bash复制代码
npm install vuex --save | |
# 或者 | |
yarn add vuex --save |
二、创建Store
在项目的src
目录下创建一个store
文件夹,并在其中创建一个index.js
文件。这个文件将用于配置和导出Vuex的store。
javascript复制代码
// src/store/index.js | |
import Vue from 'vue'; | |
import Vuex from 'vuex'; | |
Vue.use(Vuex); | |
const state = { | |
// 在这里定义你的状态 | |
count: 0, | |
// 其他状态... | |
}; | |
const mutations = { | |
// 同步修改状态的方法 | |
increment(state) { | |
state.count++; | |
}, | |
decrement(state) { | |
state.count--; | |
}, | |
// 其他mutations... | |
}; | |
const actions = { | |
// 异步操作或复杂逻辑,最终调用mutations来修改状态 | |
incrementAsync({ commit }) { | |
setTimeout(() => { | |
commit('increment'); | |
}, 1000); | |
}, | |
// 其他actions... | |
}; | |
const getters = { | |
// 基于state计算属性,用于获取一些派生状态 | |
doubleCount: state => state.count * 2, | |
// 其他getters... | |
}; | |
export default new Vuex.Store({ | |
state, | |
mutations, | |
actions, | |
getters, | |
}); |
三、在Vue实例中引入Store
在main.js
文件中引入并挂载store:
javascript复制代码
// src/main.js | |
import Vue from 'vue'; | |
import App from './App.vue'; | |
import store from './store/index.js'; | |
Vue.config.productionTip = false; | |
new Vue({ | |
render: h => h(App), | |
store, // 将store挂载到Vue实例上 | |
}).$mount('#app'); |
四、在组件中使用Vuex
- 访问State:
在组件中,你可以通过this.$store.state.xxx
来访问状态,但更好的做法是使用mapState
辅助函数将状态映射为计算属性。
javascript复制代码
<template> | |
<div> | |
<p>Count: {{ count }}</p> | |
</div> | |
</template> | |
<script> | |
import { mapState } from 'vuex'; | |
export default { | |
computed: { | |
...mapState({ | |
count: state => state.count, | |
}), | |
}, | |
}; | |
</script> |
- 提交Mutation:
你可以通过this.$store.commit('xxx')
来提交mutation,同样地,使用mapMutations
辅助函数可以将mutation映射为方法。
javascript复制代码
<template> | |
<div> | |
<button @click="increment">Increment</button> | |
<button @click="decrement">Decrement</button> | |
</div> | |
</template> | |
<script> | |
import { mapMutations } from 'vuex'; | |
export default { | |
methods: { | |
...mapMutations(['increment', 'decrement']), | |
}, | |
}; | |
</script> |
- 分发Action:
你可以通过this.$store.dispatch('xxx')
来分发action,使用mapActions
辅助函数可以将action映射为方法。
javascript复制代码
<template> | |
<div> | |
<button @click="incrementAsync">Increment Async</button> | |
</div> | |
</template> | |
<script> | |
import { mapActions } from 'vuex'; | |
export default { | |
methods: { | |
...mapActions(['incrementAsync']), | |
}, | |
}; | |
</script> |
- 使用Getters:
你可以通过this.$store.getters.xxx
来访问getters,使用mapGetters
辅助函数可以将getters映射为计算属性。
javascript复制代码
<template> | |
<div> | |
<p>Double Count: {{ doubleCount }}</p> | |
</div> | |
</template> | |
<script> | |
import { mapGetters } from 'vuex'; | |
export default { | |
computed: { | |
...mapGetters(['doubleCount']), | |
}, | |
}; | |
</script> |
五、模块化
当项目变得复杂时,可以将store拆分为多个模块(module)。每个模块拥有自己的state、mutations、actions和getters,最后是模块的namespaced
属性,用于将模块的状态和操作封装起来,避免命名冲突。
javascript复制代码
// src/store/modules/counter.js | |
const state = { | |
count: 0, | |
}; | |
const mutations = { | |
increment(state) { | |
state.count++; | |
}, | |
}; | |
const actions = { | |
incrementAsync({ commit }) { | |
setTimeout(() => { | |
commit('increment'); | |
}, 1000); | |
}, | |
}; | |
const getters = { | |
doubleCount: state => state.count * 2, | |
}; | |
export default { | |
namespaced: true, | |
state, | |
mutations, | |
actions, | |
getters, | |
}; |
在index.js
中引入并使用这些模块:
javascript复制代码
// src/store/index.js | |
import Vue from 'vue'; | |
import Vuex from 'vuex'; | |
import counter from './modules/counter'; | |
Vue.use(Vuex); | |
export default new Vuex.Store({ | |
modules: { | |
counter, | |
}, | |
}); |
在组件中使用模块化后的状态和操作时,需要指定模块名:
javascript复制代码
<template> | |
<div> | |
<p>Count: {{ count }}</p> | |
<button @click="increment">Increment</button> | |
</div> | |
</template> | |
<script> | |
import { mapState, mapMutations } from 'vuex'; | |
export default { | |
computed: { | |
...mapState({ | |
count: state => state.counter.count, | |
}), | |
}, | |
methods: { | |
...mapMutations('counter', ['increment']), | |
}, | |
}; | |
</script> |
以上就是Vuex的基本使用方法,包括安装、创建Store、在Vue实例中引入Store、在组件中使用Vuex以及模块化等。通过Vuex,你可以更方便地管理Vue应用中的状态,提高代码的可维护性和可测试性。
相关文章:
vue之vuex的使用及举例
Vuex是专门为Vue.js设计的集中式状态管理架构,它允许你将所有的组件共享状态存储在一个单独的地方,即“store”,并以相应的规则保证状态以一种可预测的方式发生变化。以下是Vuex的基本使用方法: 一、安装Vuex 对于Vue 2项目&…...
使用 vite 快速初始化 shadcn-vue 项目
Vite 1. 创建项目 使用 vite 创建一个新的 vue 项目。 如果你正在使用 JS 模板,需要存在 jsconfig.json 文件才能正确运行 CLI。 # npm 6.x npm create vitelatest my-vue-app --template vue-ts# npm 7, extra double-dash is needed: npm create vitelatest m…...
微信小程序:一个小程序跳转至另一个小程序
一、微信小程序支持一个小程序跳转至另一个小程序吗? 支持。 1.1、目标小程序需开放被跳转:目标小程序需要在其 app.json 文件中配置 navigateToMiniProgramAppIdList,将源小程序的 AppID 加入其中。 1.2、用户授权:用户需要授…...
Java第二阶段---10方法带参---第二节 方法重载(Overloading)
1.概念 在同一个类中,方法名相同,参数列表不同的多个方法构造成方法重载 2.示例 public class Calculator{public int sum(int a,int b){return ab;}public int sum(int a,int b,int c){return abc;} } 3.误区 下面的方法是否属于方法重载ÿ…...
Java Web 之 Session 详解
在 JavaWeb 开发中,Session 就像网站的专属记忆管家,为每个用户保管着重要的信息和状态,确保用户在网站的旅程顺畅无阻。 场景一: 想象你去一家大型超市购物,推着购物车挑选商品。这个购物车就如同 Sessionÿ…...

63.5 注意力提示_by《李沐:动手学深度学习v2》pytorch版
系列文章目录 文章目录 系列文章目录注意力提示生物学中的注意力提示查询、键和值注意力的可视化使用 show_heatmaps 显示注意力权重代码示例 代码解析结果 小结练习 注意力提示 🏷sec_attention-cues 感谢读者对本书的关注,因为读者的注意力是一种稀缺…...
vscode 的terminal 输出打印行数限制设置
修改 VSCODE 的 settings.json文件 "terminal.integrated.scrollback": 100000, {"extensions.ignoreRecommendations": true,"workbench.colorTheme": "Monokai","explorer.confirmDelete": false,"editor.fontSize…...

深入挖掘C++中的特性之一 — 继承
目录 1.继承的概念 2.举个继承的例子 3.继承基类成员访问方式的变化 1.父类成员的访问限定符对在子类中访问父类成员的影响 2.父类成员的访问限定符子类的继承方式对在两个类外访问子类中父类成员的影响 4.继承类模版(注意事项) 5.父类与子类间的转…...
Linux 下 poll 详解
在Linux系统编程中,poll 是一个强大的多路复用(I/O 多路复用)函数,用于同时监控多个文件描述符的事件,特别是在处理网络套接字或其他I/O设备时。相比于select,poll 支持监控更多的文件描述符,并…...

virtualbox配置为NAT模式后物理机和虚拟机互通
virtualbox配置为 NAT模式后,虚拟机分配到的 IP地址一般是 10.xx网段的,虚拟机可以通过网络地址转换访问物理机所在的网络,但若不做任何配置,则物理机无法直接访问虚拟机。 virtualbox在提供 NAT配置模式时,也提供了端…...

工程机械车辆挖掘机自卸卡车轮式装载机检测数据集VOC+YOLO格式2644张3类别
数据集格式:Pascal VOC格式YOLO格式(不包含分割路径的txt文件,仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数):2644 标注数量(xml文件个数):2644 标注数量(txt文件个数):2644 标注…...

[Notepad++] 文本编辑器的下载及详细安装使用过程(附有下载文件)
程序员常用的文本编辑器Notepad,用于修改配置文件等 下载链接在文末 下载压缩包后解压 !!安装路径不要有中文 解压文件,得到 双击exe文件 选择简体中文,点击OK 点击下一步 点击“我接受” 更改安装目录,不…...

深入浅出Java多线程(六):Java内存模型
引言 大家好,我是你们的老伙计秀才!今天带来的是[深入浅出Java多线程]系列的第六篇内容:Java内存模型。大家觉得有用请点赞,喜欢请关注!秀才在此谢过大家了!!! 在并发编程中…...
注册了个小趴菜999#it#com
注册了个 999#it#com 拿着玩玩吧 现在二级域名竟然也让注册了 不过cn.com的二级似乎早就可以了...

UE4 材质学习笔记02(数据类型/扭曲着色器)
一.什么是数据类型 首先为啥理解数据类型是很重要的。一些节点的接口插槽只接受特定类型的数据,如果连接了不匹配的数据就会出现错误,有些接口可以接受任何数据类型,但是实际上只会使用到其中的一些。并且有时可以将多个数据流合并成一个来编…...

Linux驱动开发(速记版)--设备树插件
第六十八章 设备树插件介绍 Linux 4.4之后引入了动态设备树,其中的设备树插件(Device Tree Overlay)是一种扩展机制,允许在运行时动态添加、修改或删除设备节点和属性。 设备树插件机制通过DTS(设备树源文件࿰…...
代码报错后如何定位问题
文章目录 一、查看终端报错Exception二、百度三、问 一、查看终端报错Exception 代码报错时,终端一般都会有xxxException异常提示,或者exception、error…等字样提示,就顺着这些关键字提醒找到异常即可。 二、百度 不知道这个英文的异常是…...

Python数据可视化--Matplotlib--入门
我生性自由散漫,不喜欢拘束。我谁也不爱,谁也不恨。我没有欺骗这个,追求那个;没有把这个取笑,那个玩弄。我有自己的消遣。 -- 塞万提斯 《堂吉诃德》 Matplotlib介绍 1. Matplotlib 是 Python 中常用的 2D 绘图库&a…...
美国食品等级FDA认证测试介绍
美国FDA认证概览 美国食品和药物管理局(FDA)是负责监管食品、药品、医疗设备和化妆品等的联邦机构,以确保这些产品对公众健康和安全的影响。FDA认证在美国属于强制性认证,对产品的安全性和质量有着严格的要求。通过FDA认证&#…...

Vue2如何在网页实现文字的逐个显现
目录 Blue留言: 效果图: 实现思路: 代码: 1、空字符串与需渲染的字符串的定义 2、vue的插值表达式 3、函数 4、mounted()函数调用 结语: Blue留言: 在国庆前夕,突发奇想,我想…...

华为云AI开发平台ModelArts
华为云ModelArts:重塑AI开发流程的“智能引擎”与“创新加速器”! 在人工智能浪潮席卷全球的2025年,企业拥抱AI的意愿空前高涨,但技术门槛高、流程复杂、资源投入巨大的现实,却让许多创新构想止步于实验室。数据科学家…...
Android Wi-Fi 连接失败日志分析
1. Android wifi 关键日志总结 (1) Wi-Fi 断开 (CTRL-EVENT-DISCONNECTED reason3) 日志相关部分: 06-05 10:48:40.987 943 943 I wpa_supplicant: wlan0: CTRL-EVENT-DISCONNECTED bssid44:9b:c1:57:a8:90 reason3 locally_generated1解析: CTR…...
Linux链表操作全解析
Linux C语言链表深度解析与实战技巧 一、链表基础概念与内核链表优势1.1 为什么使用链表?1.2 Linux 内核链表与用户态链表的区别 二、内核链表结构与宏解析常用宏/函数 三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势5.1 插入效率5.2 安全…...

python/java环境配置
环境变量放一起 python: 1.首先下载Python Python下载地址:Download Python | Python.org downloads ---windows -- 64 2.安装Python 下面两个,然后自定义,全选 可以把前4个选上 3.环境配置 1)搜高级系统设置 2…...
工程地质软件市场:发展现状、趋势与策略建议
一、引言 在工程建设领域,准确把握地质条件是确保项目顺利推进和安全运营的关键。工程地质软件作为处理、分析、模拟和展示工程地质数据的重要工具,正发挥着日益重要的作用。它凭借强大的数据处理能力、三维建模功能、空间分析工具和可视化展示手段&…...
使用van-uploader 的UI组件,结合vue2如何实现图片上传组件的封装
以下是基于 vant-ui(适配 Vue2 版本 )实现截图中照片上传预览、删除功能,并封装成可复用组件的完整代码,包含样式和逻辑实现,可直接在 Vue2 项目中使用: 1. 封装的图片上传组件 ImageUploader.vue <te…...
在Ubuntu中设置开机自动运行(sudo)指令的指南
在Ubuntu系统中,有时需要在系统启动时自动执行某些命令,特别是需要 sudo权限的指令。为了实现这一功能,可以使用多种方法,包括编写Systemd服务、配置 rc.local文件或使用 cron任务计划。本文将详细介绍这些方法,并提供…...
leetcodeSQL解题:3564. 季节性销售分析
leetcodeSQL解题:3564. 季节性销售分析 题目: 表:sales ---------------------- | Column Name | Type | ---------------------- | sale_id | int | | product_id | int | | sale_date | date | | quantity | int | | price | decimal | -…...

【Java_EE】Spring MVC
目录 Spring Web MVC 编辑注解 RestController RequestMapping RequestParam RequestParam RequestBody PathVariable RequestPart 参数传递 注意事项 编辑参数重命名 RequestParam 编辑编辑传递集合 RequestParam 传递JSON数据 编辑RequestBody …...
OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别
OpenPrompt 和直接对提示词的嵌入向量进行训练有什么区别 直接训练提示词嵌入向量的核心区别 您提到的代码: prompt_embedding = initial_embedding.clone().requires_grad_(True) optimizer = torch.optim.Adam([prompt_embedding...