简单的vuex使用

简单的vuex使用

Vuex是一个专门为Vue.js应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,解决多组件数据通信问题

配置vuex

1, 安装vuex, vue2版本对应的事vuex3

npm i vuex@3

2, 配置vuex, 在src文件夹下建立store文件夹并建立index.js

import Vue from 'vue'
import Vuex from 'vuex'

import test from './modus/test.js'

Vue.use(Vuex)
export default new Vuex.Store({
	namespaced: true, // 作用是隔离模块的状态管理,避免命名冲突,并提高代码的可维护性和可读性
	modules: {
		// 引入的模块js, 也可以将所有数据写到index.js里, 建议按模块建立文件
		test
	}
})

在main.js里引入vux

import store from '@/store'

new Vue({
  store,
  render: h => h(App)
}).$mount('#app')

基本方法

在store文件夹下建立modus文件夹并建立test.js文件
在这里插入图片描述

state属性:基本数据;
getters属性:从 state 中派生出的数据;
mutation属性:更新 store 中数据的唯一途径,其接收一个以 state 为第一参数的回调函数;
action 属性:提交 mutation 以更改 state,其中可以包含异步操作;
module 属性:用于将 store分割成不同的模块。

1, state

包含了store中存储的各个数据, 使用方法:

export default {
	state: {
		name: '曹操',
	}
}

如果在vue文件里想要给name赋值或者取值方法如下:

// 取值
let storeName = this.$store.state.test.name;

// 赋值
this.$store.state.test.name = '曹丕'

2, mutations

export default {
	state: {
		name: '曹操',
	},
	mutations: {
		// 更新name
		setName(state, payload){
			state.name = payload.name;
		}
	}
}

在vue文件里调用mutations里的方法,使用commit

let params = {
	name: '曹丕'
}
this.$store.state.commit('setName', params)

3, actions 获取异步数据并给state的字段复制

export default {
	state: {
		name: '曹操',
	},
	mutations: {
		// 更新name
		setName(state, payload){
			state.name = payload.name;
		}
	},
	actions: {
		getName({commit}, params){
			http.get('/getName',{
				params
			}).then(res => {
				commit('setName', res);
			})
		}
	}
}

在vue文件里调用actions里的方法使用dispatch

let params = {} // 参数
this.$store.dispatch('getName', params)
在 Uniapp 中使用 Vuex,可以实现全局状态管理。下面是一个简单的示例,介绍如何在 Uniapp 中使用 Vuex。 1. 首先,在你的项目中安装 Vuex: ```bash npm install vuex ``` 2. 在你的项目中创建一个 `store` 目录,用于存放 Vuex 相关的文件。 3. 在 `store` 目录下创建一个 `index.js` 文件,用于配置 Vuex 的核心内容。 ```javascript // store/index.js import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) const store = new Vuex.Store({ state: { count: 0 }, mutations: { increment(state) { state.count++ }, decrement(state) { state.count-- } }, actions: { increment(context) { context.commit('increment') }, decrement(context) { context.commit('decrement') } }, getters: { getCount(state) { return state.count } } }) export default store ``` 在上述代码中,我们定义了一个包含 `state`、`mutations`、`actions` 和 `getters` 的 Vuex store。`state` 用于存储应用的状态,`mutations` 用于修改状态,`actions` 用于提交 mutations,`getters` 用于获取状态。 4. 在主入口文件 `main.js` 中导入并挂载 Vuex store: ```javascript // main.js import Vue from 'vue' import App from './App' import store from './store' Vue.config.productionTip = false App.mpType = 'app' const app = new Vue({ store, ...App }) app.$mount() ``` 在上述代码中,我们将创建的 Vuex store 对象导入并挂载到 Vue 实例上,这样就可以在整个应用中共享该 store 中定义的状态和方法。 5. 现在,你可以在组件中使用 Vuex 了。例如,在一个组件中获取和修改状态: ```vue <template> <div> <p>Count: {{ count }}</p> <button @click="increment">Increment</button> <button @click="decrement">Decrement</button> </div> </template> <script> export default { computed: { count() { return this.$store.getters.getCount } }, methods: { increment() { this.$store.dispatch('increment') }, decrement() { this.$store.dispatch('decrement') } } } </script> ``` 在上述代码中,我们通过 `$store` 访问 Vuex store 对象,使用 `getters` 获取状态,使用 `dispatch` 提交 actions。 这样,你就可以在 Uniapp 中使用 Vuex 进行全局状态管理了。希望对你有所帮助!如果有任何疑问,请随时提出。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值