VueJS:如何在组件数据属性中引用此。$ store

时间:2017-04-27 15:20:05

标签: javascript vue.js vue-component vuex

我想在我的应用和模板中使用我的Vuex商店数据。

My Veux商店:

var Vue = require('vue');
var Vuex = require('vuex');

Vue.use(Vuex)

let store = new Vuex.Store({
        state: {
            user: {},
        },
    }
}
module.exports = store

我想在我的应用中使用商店数据并将其显示在模板中。但是,在data属性中设置数据时,this.$storeundefined。但是,我可以在beforeRender函数中访问它:

var Vue = require('vue'),
store = require('../../link/to/my/store');

module.exports = {
    el: '#selector',

    store,

    components: {},

    data: {
        saving: false,
        user: this.$store.state.user // this.state is not available here
    },

    created: function(){},
    beforeCreate: function() {

        console.log(this.$state.state) // this.$state is available here

        // i get my data in the form of a json string from the dom
        // and update the global store with the data
        let user = document.querySelector('#user-data')
        if (user) this.$store.dispatch('updateUser', JSON.parse(user.innerHTML))

    },

    methods: {}

    }
};

我也尝试过计算属性,但无济于事。

1 个答案:

答案 0 :(得分:5)

根据Vue documentation

  

定义组件时,必须将数据声明为返回初始数据对象的函数。

所以,改变:

data: {
    saving: false,
    user: this.$store.state.user
},

到此:

data: function () {
  return {
    saving: false,
    user: this.$store.state.user
  };
}

然后,函数中的this将引用$store