vuex store的运用

发布时间:2019-01-10 整理:脚本之家 作者:未知
脚本之家收集整理的这篇文章主要介绍了vuex store的运用脚本之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随脚本之家小编过来看看吧!

vuex用来管理vue的所有组件状态。 首先下载vuex,”vuex”:”^3.0.1”,运用”vuex-persistedstate”来对数据进行缓存。下载”vuex-persistedstate” 在文件中引入:(新建一个store文件夹,在文件夹下的index.js文件进行如下编写)

import Vue from 'vue'
import Vuex from 'vuex'
import createPersistedState from 'vuex-persistedstate'
Vue.use(Vuex)

定义简单模块:

const module = {
    state: {
        user: {
            name: 'rookie'
        }
    },getters: {},mutations: {
        setUser(state,payload){
            if(payload.hasOwnProperty('name')){
                state.user.name = payload.name
            }
        }
    },plugins: [createPersistedState()]
}

上面是一个简单的vuex,在vuex中对应的store应用,在store中包含组件的共享状态state和改变状态的方法(暂且称作方法)mutations。注意state相当于对外的只读状态,不能通过store.state.user.name来更改,使用store.commit方法通过触发mutations改变state。 在页面中获取记录的值name为rookie

mounted(){
    console.log(this.$store.state.user.name);
}

store.state为获取store中的值,此时在my页面中打印出来的值为rookie,而我们想要修改name的值,则需要借助store.commit方法来触发mutations:

this.$store.commit('setUser',{name: 'kuke_kuke'})

在mutations中找到setUser,第二个参数payload为传入的对象{name: ‘kuke_kuke’},调用方法hadOwnProperty来判断传入的对象是否有name属性,从而修改state中的值,此时在页面中再次打印user.name的值为’kuke _ kuke’。 最后导出模块:

const store = new Vuex.Store(module)
export default store

别忘记在main.js中获取模块并使用:

import store from './store'
new Vue({
    store
})

作者:rookie.he(kuke_kuke) 博客链接:http://blog.csdn.net/qq_33599109 欢迎关注支持,谢谢!

总结

以上是脚本之家为你收集整理的vuex store的运用全部内容,希望文章能够帮你解决vuex store的运用所遇到的程序开发问题。

如果觉得脚本之家网站内容还不错,欢迎将脚本之家网站推荐给程序员好友。

标签: