vuex的简介
官方定义
Vuex是一个专门为Vue.js应用程序开的状态管理模式
它采用集中式存储管理应用的所有组件的状态
并以相应的规则保证以一种可预测的方式发生变化
应用场景
多个视图依赖同一状态
来自不同视图的行为需要改变同一个状态
Vuex的组成介绍
State --- 数据仓库
getter --- 用来获取数据的
Mutation --- 用来修改数据的
Action --- 用来提交mutation
安装Vuex
安装vuex包:npm install vuex
创建vuex实例:new Vuex.store()
main.js中将vuex实例挂载到vue对象上
实战vuex 实现count++ 基本demo
state中创建count字段
muntation中创建一个count++的mutation
button新增click事件触发mutation改变count
<template>
<div id="app">
<!-- <img alt="Vue logo" src="./assets/logo.png">
<HelloWorld msg="Welcome to Your Vue.js App"/> -->
<h1>count:{{count}}</h1>
<button @click="countIncrease">点我</button>
</div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
name: 'app',
components: {
HelloWorld
},
computed:{
count() {
return this.$store.state.count;
}
},
methods:{
countIncrease() {
const v = 100
this.$store.commit('countIncrease',v)
}
}
}
</script>
import Vue from 'vue'
import App from './App.vue'
import Vuex from 'vuex'
Vue.config.productionTip = false
Vue.use(Vuex)
const store = new Vuex.Store({
state: {
count: 0
},
mutations:{
countIncrease(state,v){
state.count = v
}
}
})
new Vue({
store,
render: h => h(App),
}).$mount('#app')
案例讲解(业务目标)
制作一个需要账号登录的课程学习项目
不同的课程需要不同的会员等级,实现购买会员功能,课程分享
功能
通过state.userInfo控制用户登录路由限制
多组件共享state.userStatus和state.vipLeve状态
多组件修改state.userStatus和state.vipLevel
data:image/s3,"s3://crabby-images/ee92b/ee92b546b65b9d2aef3d477f49f757d3a9fe2dd6" alt=""
image.png
data:image/s3,"s3://crabby-images/63267/63267ae4a981c304849fc3372b4f8b28cdeafce2" alt=""
image.png
data:image/s3,"s3://crabby-images/f0a9b/f0a9b3d472cfe01f5c42558ff05819c3f2d71306" alt=""
image.png
data:image/s3,"s3://crabby-images/6f570/6f570cfaad2cb7f9efed84a928ff1eaf8e2b3940" alt=""
image.png
结构方法
data:image/s3,"s3://crabby-images/b07b7/b07b726e84a415791dbd809c79ce66736d91502e" alt=""
image.png
data:image/s3,"s3://crabby-images/3d967/3d9675e5fdfc8f89b0213e6775c7201ed26d0de1" alt=""
image.png
data:image/s3,"s3://crabby-images/29d62/29d623aea849918604ca93fec6dc44270a42d94d" alt=""
image.png
data:image/s3,"s3://crabby-images/1cf02/1cf02ae5ba113d7b38b4e01308daa302eab2fd5f" alt=""
image.png
data:image/s3,"s3://crabby-images/27fcb/27fcb84b67e82c1a2f95d8f1dbd046acf549afe8" alt=""
image.png
data:image/s3,"s3://crabby-images/6d20b/6d20b9c23527376360023d8fd0ff08490750d48d" alt=""
image.png
data:image/s3,"s3://crabby-images/e79a4/e79a4719585549da8a3e45b9c8ebec5ca540b0d7" alt=""
image.png
data:image/s3,"s3://crabby-images/f2bef/f2befd9064a10b0853231e7fe6256339ab3867c1" alt=""
image.png
data:image/s3,"s3://crabby-images/27551/27551aa68e5e0a25d71ea31dbc5820b35ac6e39b" alt=""
image.png
data:image/s3,"s3://crabby-images/626a0/626a0f15b0cd600051943fee17805a0b9cecff25" alt=""
image.png
data:image/s3,"s3://crabby-images/78f3a/78f3acafae51687e9c3d9885bcdb70d3d94488cf" alt=""
image.png
网友评论