vuex插件
data:image/s3,"s3://crabby-images/bde29/bde29cd1c8e0674369c2d93f75b87bd712e1e9e4" alt="在这里插入图片描述"
使用条件 data:image/s3,"s3://crabby-images/1533e/1533e14deb697ffafa9ea2fffe5964bbe9cfa5b9" alt="在这里插入图片描述"
实现多组件共享数据的方法
方法一:全局事件中线(乱)
data:image/s3,"s3://crabby-images/8cc33/8cc334e600721b12173b44f085fad376213d1abf" alt="在这里插入图片描述"
方法二:vuex实现多数组共享数据√
data:image/s3,"s3://crabby-images/e5a2f/e5a2f85b2229725b5359aeba045db59c1387f229" alt="在这里插入图片描述"
vuex工作原理
data:image/s3,"s3://crabby-images/58c49/58c4973207637c42d5ed78567f86e3b83535ec7c" alt="在这里插入图片描述" 如下图, 如果知道自己要做什么, 也知道数据可以跳过上方API data:image/s3,"s3://crabby-images/cb6d3/cb6d3052d53ed7e01e3c6f886d8a4f8bb0616d97" alt="在这里插入图片描述" 如下图,dispatch、commit方法都是store的。 data:image/s3,"s3://crabby-images/78681/786810930af75fecba0407d80e0efbac6e710bce" alt="在这里插入图片描述"
vue2中使用vuex小结:
data:image/s3,"s3://crabby-images/229ac/229ace1a79f0ccc7e97a47b41bb87f59d9c72abe" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/631c9/631c9b6f2a8bd040fcc6eb0535e1073b138b6323" alt="在这里插入图片描述" 基本使用 data:image/s3,"s3://crabby-images/92b9e/92b9ede49b311ebdbd6b261af64758be26bbca8a" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/82082/82082a399d0d681f212242be96b61394cb43f96e" alt="在这里插入图片描述"
vue3搭建vuex环境
步骤总览
data:image/s3,"s3://crabby-images/2f329/2f329c145cd4553e750d87607a5447253328f74a" alt="在这里插入图片描述"
简单vuex实例
data:image/s3,"s3://crabby-images/cb6d3/cb6d3052d53ed7e01e3c6f886d8a4f8bb0616d97" alt="在这里插入图片描述" state用于存储数据 getters 加工数据
1.命令行安装vuex data:image/s3,"s3://crabby-images/23204/2320475822e1e2d54ad00913892cb645942bd433" alt="在这里插入图片描述" npm i vuex@版本 –save放入依赖
npm i vuex@4 --save
2.在main.js 中引入并使用vuex 创建一个store 实例
import { createApp } from 'vue'
import App from './App.vue'
import { createStore } from "vuex";
const store = createStore({
state(){
return{
sum:0
}
},actions:{
}
,mutations:{
}
})
const app=createApp(App)
app.use(store)
app.mount('#app')
3.在模板中使用
<template>
<div>
<h1>当前求和为:{{ $store.state.sum }}</h1>
</div>
</template>
4.发送到actions进行处理
methods: {
increment() {
this.$store.dispatch("increment", this.selectNum);
},
}
4.在actions阶段, 用context 参数调用commit进入mutations 阶段,注意第一参数全部大写.
actions:{
increment(context,value){
context.commit('INCREMENT', value)
}
},
如果跳过actions 阶段, 用commit 直接进入mutations阶段 commit 的第一个参数要全大写
methods: {
increment() {
this.$store.commit("INCREMENT", this.selectNum);
},
},
5.在mutations 内编写对应函数
const store = createStore({
state(){
return{
sum:0,
}
},actions:{
},mutations:{
INCREMENT(state,value){
state.sum+=value;
},
}
})
getters的使用
vuex实例中的getters用来对state内的数据进行加工使用 可以类比data和computed 1.在main.js 中的vuex实例(即store)配置
const store = createStore({
state(){
return{
sum:0,
}
},
actions:{},
mutations:{},
getters:{
bigSum(state){
return state.sum*10;
}
}
})
2.在模板中使用{{ $store.getters.bigSum }}
<template>
<div>
<h1>当前求和为:{{ $store.state.sum }}</h1>
<h2>当前求和扩大十倍后为:{{ $store.getters.bigSum }}</h2>
</div>
</template>
小结: data:image/s3,"s3://crabby-images/7ea10/7ea105caaa1d13500b9af40a9c08bc89b3f1c0ba" alt="在这里插入图片描述"
|