目录
1、引入依赖:
2、新建文件夹 store ,在里面新建文件 index.js
3、index.js文件内容:
4、在 main.js 中引入
5、使用
6、修改 count 的值,这个和在 vue2 中的写法一样:
1、引入依赖:
npm i vuex
2、新建文件夹 store ,在里面新建文件 index.js
data:image/s3,"s3://crabby-images/3783d/3783df376c0ebff9583181f47bb99466bf984e8a" alt=""
3、index.js文件内容:
import { createStore } from 'vuex'
export default createStore({
state: {
},
mutations: {
},
actions: {
},
modules: {
}
})
4、在 main.js 中引入
import store from './store'
5、使用
在 store/index.js 的 state 中添加 count: 0
data:image/s3,"s3://crabby-images/d2fac/d2fac23def37a2447f2b79a768df248850f87ecb" alt=""
在任一组件文件中:加入下面代码:
import { useStore } from "vuex";
export default {
name: "App",
setup() {
// Vue3 有个 composition api 的入口
const store = useStore();// 获取容器
},
};
data:image/s3,"s3://crabby-images/0c293/0c2939eea200010836472483db8d735e6b133c76" alt=""
获取到容器 store 后 ,获取 Vuex 中的 count 的值,通过?store.state.count 来获取。
data:image/s3,"s3://crabby-images/2900f/2900fd25c2805572f2b581b89b4ea79a9d2ce73a" alt=""
?data:image/s3,"s3://crabby-images/7ef53/7ef537b563e813314bd399d5d033e46fbc31be5e" alt=""
直接在 template 中使用,目前可以使用旧版本写法
data:image/s3,"s3://crabby-images/3203d/3203db77eb6aeea05e7cc3ace095a92c1028e6cb" alt=""
?如果想要字段?count 改变后,页面显示数据也改变,需要引入 vue?的计算属性 computed
<template>
<img alt="Vue logo" src="./assets/logo.png" />
<h1>Vuex</h1>
<h1>{{ count }}</h1>
</template>
<script>
import { computed } from "vue";
import { useStore } from "vuex";
export default {
name: "App",
setup() {
// Vue3 有个 composition api 的入口
const store = useStore(); // 获取容器
// 获取 Vuex 中的 count 的值
console.log("store.state.count", store.state.count);
return {
count: computed(() => store.state.count),
};
},
};
</script>
data:image/s3,"s3://crabby-images/8ae76/8ae76c609f5eb302cba7dcedf936742a919a33ad" alt=""
6、修改 count 的值,这个和在 vue2 中的写法一样:
在 store/index.js 中添加下面代码:
mutations: {
add(state, payload) {
state.count += payload
}
},
在 要修改? count 的值的组件中通过 commit 来修改
store.commit('add', 3)
data:image/s3,"s3://crabby-images/f3848/f3848f6418f21ddf188b6eea568e58faf16a137e" alt=""
|