vuex详解
vuex的介绍
vuex
是vue.js
应用程序中的状态管理模式
,它是集中式存储管理所有组件的数据状态,vuex解决了多个视图之间的数据交互同步,不需要进行组件连接再传递数据。
vuex的5大模块
state
:用于数据的存储,是store中的唯一数据源
const state = { // 初始化两个组件的数据源,用于操作 A: '', B: '' }复制代码
getters:
是一种计算属性,对state数据进行操作,常用于数据的筛选和多个数据的相关性计算
//定义 getters: { filteredList: state => { return state.list.filter(item => item > 5) } } //调用 this.$store.getters.filteredList;复制代码
mutations
:是一种函数集合的对象,用于在里面改变state数据,但不能用于处理异步事件
const mutations = { receiveA(state, datas) { // 接收A的数据存放于state state.A = datas.A }, receiveB(state, datas) { // 接收B的数据存放于state state.B = datas.B } } //调用mutations的方法,用commit触发 this.$store.commit('receiveA', { A: '我是A' })复制代码
actions
:类似于mutation
,用于提交mutation
来改变状态,而不直接变更状态,可以包含任意异步操作
const actions = { setNum(content){ //复制的一份store return new Promise((resolve)=>{//异步操作 setTimeout(()=>{ console.log('改变状态') resolve() },1000) }) } } //调用actions,用dispatch触发 this.$store.dispatch('setNum') //actions使用dispatch进行触发,就像mutation使用commit触发一样复制代码
modules
:vuex中的命名空间,便于维护项目中将各个模块的状态分开定义和操作
vuex示例代码:
const store = new Vuex.Store({ state:{ // 初始化两个组件的数据源,用于操作 A: '', B: '' }, getters: { filteredList: state => { return state.list.filter(item => item > 5)//过滤小于5的值 } }, mutations:{ receiveA(state, datas) { // 接收A的数据存放于state state.A = datas.A }, receiveB(state, datas) { // 接收B的数据存放于state state.B = datas.B } }, actions:{ setNum(content){ //复制的一份store return new Promise((resolve)=>{//异步操作 setTimeout(()=>{ console.log('进行改变状态操作') resolve() },1000) }) } } })复制代码
vuex运用场景
-
页面与页面之间产生各种公共变量。
-
页面头部组件下,购物数量显示。
-
全局变量也可以用vuex来存储。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix