最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

Vuex状态管理应如何使用

来源:懂视网 责编:小采 时间:2020-11-27 19:54:47
文档

Vuex状态管理应如何使用

Vuex状态管理应如何使用:这次给大家带来Vuex状态管理应如何使用,Vuex状态管理使用的注意事项有哪些,下面就是实战案例,一起来看一下。Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发
推荐度:
导读Vuex状态管理应如何使用:这次给大家带来Vuex状态管理应如何使用,Vuex状态管理使用的注意事项有哪些,下面就是实战案例,一起来看一下。Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发
这次给大家带来Vuex状态管理应如何使用,Vuex状态管理使用的注意事项有哪些,下面就是实战案例,一起来看一下。

Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。Vuex 也集成到 Vue 的官方调试工具 devtools extension,提供了诸如零配置的 time-travel 调试、状态快照导入导出等高级调试功能。

以上是vuex的官方文档对vuex的介绍,官方文档对vuex的用法进行了详细的说明。这里就不再细讲vuex的各个用法,写这篇博客的目的只是帮助部分同学更快地理解并上手vuex。

1. 安装

$ npm install vuex --save

2. 在main.js 主入口js里面引用store.js

import Vue from 'vue'
import App from './App'
import router from './router' 
import store from './vuex/store' //引用store.js
Vue.config.productionTip = false //阻止在启动时生成生产提示 
//vue实例
new Vue({
 el: '#app',
 router,
 store, //把store挂在到vue的实例下面
 template: '<App/>',
 components: { App }
})

3. 在store.js里引用Vuex

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex) //注册Vuex
// 定义常量 如果访问他的话,就叫访问状态对象
const state = {
 count: 1
}
// mutations用来改变store状态, 如果访问他的话,就叫访问触发状态
const mutations = {
 //这里面的方法是用 this.$store.commit('jia') 来触发
 jia(state){
 state.count ++
 },
 jian(state){
 state.count --
 },
}
//暴露到外面,让其他地方的引用
export default new Vuex.Store({
 state,
 mutations
})

4. 在vue组件中使用

使用$store.commit('jia')区触发mutations下面的加减方法

<template>
 <p class="hello">
 <h1>Hello Vuex</h1>
 <h5>{{$store.state.count}}</h5>
 <p>
 <button @click="$store.commit('jia')">+</button>
 <button @click="$store.commit('jian')">-</button>
 </p>
 </p>
</template>
<!-- 加上scoped是css只在这个组件里面生效,为了不影响全局样式 -->
<style scoped>
 h5{
 font-size: 20px;
 color: red;
 }
</style>

5. 查看演示

浅谈Vuex的状态管理(全家桶)

6. state访问状态对象

使用computed计算

<template>
 <p class="hello">
 <h1>Hello Vuex</h1>
 <h5>{{count}}</h5>
 <p>
 <button @click="$store.commit('jia')">+</button>
 <button @click="$store.commit('jian')">-</button>
 </p>
 </p>
</template>
<script>
import {mapState} from 'vuex'
export default{
 name:'hello', //写上name的作用是,如果你页面报错了,他会提示你是那个页面报的错,很实用
 // 方法一
 // computed: {
 // count(){
 // return this.$store.state.count + 6
 // }
 // }
 
 // 方法二 需要引入外部 mapState
 computed:mapState({
 count:state => state.count + 10
 })
 
 // ECMA5用法
 // computed:mapState({
 // count:function(state){
 // return state.count
 // }
 // })
 
 //方法三
 // computed: mapState([
 // 'count'
 // ])
 }
</script>

7. mutations触发状态 (同步状态)

<template>
 <p class="hello">
 <h1>Hello Vuex</h1>
 <h5>{{count}}</h5>
 <p>
 <button @click="jia">+</button>
 <button @click="jian">-</button>
 </p>
 </p>
</template>
<script>
import {mapState,mapMutations} from 'vuex'
 export default{
 name:'hello', //写上name的作用是,如果你页面报错了,他会提示你是那个页面报的错,很实用
 //方法三
 computed: mapState([
 'count'
 ]),
 methods:{
 ...mapMutations([
 'jia',
 'jian'
 ])
 }
 }
</script>

8. getters计算属性

getter不能使用箭头函数,会改变this的指向

在store.js添加getters

// 计算
const getters = {
 count(state){
 return state.count + 66
 }
}
export default new Vuex.Store({
 state,
 mutations,
 getters
})
//count的参数就是上面定义的state对象
//getters中定义的方法名称和组件中使用的时候一定是一致的,定义的是count方法,使用的时候也用count,保持一致。
组件中使用
<script>
 import {mapState,mapMutations,mapGetters} from 'vuex'
 export default{
 name:'hello',
 computed: {
 ...mapState([
 'count'
 ]),
 ...mapGetters([
 'count'
 ])
 },
 methods:{
 ...mapMutations([
 'jia',
 'jian'
 ])
 }
 }
</script>

9. actions (异步状态)

在store.js添加actions

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
// 定义常量
const state = {
 count: 1
}
// mutations用来改变store状态 同步状态
const mutations = {
 jia(state){
 state.count ++
 },
 jian(state){
 state.count --
 },
}
// 计算属性
const getters = {
 count(state){
 return state.count + 66
 }
}
// 异步状态
const actions = {
 jiaplus(context){
 context.commit('jia') //调用mutations下面的方法
 setTimeout(()=>{
 context.commit('jian')
 },2000)
 alert('我先被执行了,然后两秒后调用jian的方法')
 },
 jianplus(context){
 context.commit('jian')
 }
}
export default new Vuex.Store({
 state,
 mutations,
 getters,
 actions
})

在组件中使用

<template>
 <p class="hello">
 <h1>Hello Vuex</h1>
 <h5>{{count}}</h5>
 <p>
 <button @click="jia">+</button>
 <button @click="jian">-</button>
 </p>
 <p>
 <button @click="jiaplus">+plus</button>
 <button @click="jianplus">-plus</button>
 </p>
 </p>
</template>
<script>
 import {mapState,mapMutations,mapGetters,mapActions} from 'vuex'
 export default{
 name:'hello',
 computed: {
 ...mapState([
 'count'
 ]),
 ...mapGetters([
 'count'
 ])
 },
 methods:{
 // 这里是数组的方式触发方法
 ...mapMutations([
 'jia',
 'jian'
 ]),
 // 换一中方式触发方法 用对象的方式
 ...mapActions({
 jiaplus: 'jiaplus',
 jianplus: 'jianplus'
 })
 }
 }
</script>
<style scoped>
 h5{
 font-size: 20px;
 color: red;
 }
</style>

10. modules 模块

适用于非常大的项目,且状态很多的情况下使用,便于管理

修改store.js

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
const state = {
 count: 1
}
const mutations = {
 jia(state){
 state.count ++
 },
 jian(state){
 state.count --
 },
}
const getters = {
 count(state){
 return state.count + 66
 }
}
const actions = {
 jiaplus(context){
 context.commit('jia') //调用mutations下面的方法
 setTimeout(()=>{
 context.commit('jian')
 },2000)
 alert('我先被执行了,然后两秒后调用jian的方法')
 },
 jianplus(context){
 context.commit('jian')
 }
}
//module使用模块组的方式 moduleA
const moduleA = {
 state,
 mutations,
 getters,
 actions
}
// 模块B moduleB
const moduleB = {
 state: {
 count:108
 }
}
export default new Vuex.Store({
 modules: {
 a: moduleA,
 b: moduleB,
 }
})

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

Vuex状态管理应如何使用

Vuex状态管理应如何使用:这次给大家带来Vuex状态管理应如何使用,Vuex状态管理使用的注意事项有哪些,下面就是实战案例,一起来看一下。Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发
推荐度:
标签: 使用 VUE 状态
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top