JavaScript

超轻量级php框架startmvc

Vuex中实现数据状态查询与更改

更新时间:2020-09-21 17:00:01 作者:startmvc
在vuex进行vue注入后即可在任一子组件中通过this.$store来访问vueximportstorefrom'./store'newVue({el:'#a

在vuex进行vue注入后即可在任一子组件中通过this.$store来访问vuex


import store from './store' 
new Vue({
 el: '#app',
 router,
 store,
 components: { App },
 template: '<App/>'
})

1.在子组件中通过this.$store.state.变量名在子组件中访问state中某个变量的值

this.tabbarActive = this.$store.state.tabbarActive //这里的tabbarActive为存储在vuex中state的变量名

2.在子组件中通过this.$store.commit(‘方法名',参数)来进行对vuex中的数据状态进行更新/插入

1)由于vuex中store的改变唯一的途径是提交mutation,通过调用实例化后的vuex,mutations中相对应的方法可以实现对状态值的改变,其中payload可以为参数对象,或者单个值,state参数在调用时默认为第一个参数可以不传,但是在mutations中申明该函数时必须传入state


 mutations: {
 changeTarBar (state,payload) {
 state.tabbarActive = payload
 }
 }

–在子组件中更新store中的状态


this.$store.commit("changeTarBar",idx)//其中idx为传入的参数

–或者这种写法,此时的payload则为一个参数对象,可以通过payload.idx获得子组件传入的参数值


 this.$store.commit({
 type:'changeTarBar',//type对应方法名
 idx,
 })

以上这篇Vuex中实现数据状态查询与更改就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

Vuex 状态 查询 更改