Vue 模块化使用 Vuex

Vuex 是 Vue.js 的状态管理模式和库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式和库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。

下面是一个简单的 Vuex 使用示例:

首先,你需要安装 Vuex。你可以通过 npm 安装:

复制代码
`npm install vuex --save`

在你的 Vue 项目中创建一个新的文件来作为你的 store,例如 store.js

复制代码
`import Vue from 'vue';
import Vuex from 'vuex';

Vue.use(Vuex);

export default new Vuex.Store({
state: {
count: 0,
},
mutations: {
increment (state) {
state.count++;
},
},
actions: {
incrementIfOddOnRootSum ({ commit, state }) {
if ((state.count + this.sum) % 2 === 1) {
commit('increment')
}
}
},
modules: {
// 这里可以定义子模块,每个子模块拥有自己的 state、mutation、action、getters
}
});`

在你的 Vue 组件中,你可以这样使用 store:

复制代码
`<template>
<div>
<p>Count: {``{ count }}</p>
<button @click="increment">Increment</button>
</div>
</template>

<script>
import { mapState, mapMutations } from 'vuex';

export default {
computed: { ...mapState(['count']) },
methods: { ...mapMutations(['increment']) },
};
</script>`

在这个例子中,我们定义了一个简单的 store,包含一个 state 和一个 mutation。在 Vue 组件中,我们使用了 mapStatemapMutations 这两个辅助函数来方便地从 store 中获取状态和方法。

相关推荐
漂流瓶jz4 小时前
Webpack中各种devtool配置的含义与SourceMap生成逻辑
前端·javascript·webpack
这是个栗子4 小时前
【问题解决】用pnpm创建的 Vue3项目找不到 .eslintrc.js文件 及 后续的eslint配置的解决办法
javascript·vue.js·pnpm·eslint
前端架构师-老李4 小时前
React 中 useCallback 的基本使用和原理解析
前端·react.js·前端框架
木易 士心5 小时前
CSS 中 `data-status` 的使用详解
前端·css
明月与玄武5 小时前
前端缓存战争:回车与刷新按钮的终极对决!
前端·缓存·回车 vs 点击刷新
花姐夫Jun5 小时前
基于Vue+Python+Orange Pi Zero3的完整视频监控方案
vue.js·python·音视频
牧马少女5 小时前
css 画一个圆角渐变色边框
前端·css
zy happy5 小时前
RuoyiApp 在vuex,state存储nickname vue2
前端·javascript·小程序·uni-app·vue·ruoyi
小雨青年6 小时前
Cursor 项目实战:AI播客策划助手(二)—— 多轮交互打磨播客文案的技术实现与实践
前端·人工智能·状态模式·交互
Nan_Shu_6146 小时前
学习:JavaScript(5)
开发语言·javascript·学习