【问题标题】:Vue Router & Vuex : Getters are undefined on page refreshVue Router 和 Vuex:Getter 在页面刷新时未定义
【发布时间】:2020-02-24 13:15:22
【问题描述】:

我想根据商店的 getter 中存在的票创建一个中间件

我首先使用查询初始化 Vuejs 以生成我的状态

TicketStore.js



const getters = {
    getTickets: state => state.tickets,
    getTicketById: (state) => (id) => {
        return state.tickets.find(ticket => ticket.id === id)
    },

    //get nb of ticket for tabs
    nbTicket: state => state.tickets.length
};


const actions = { 

   .... ,

getTicketsFromAPI({commit}) {
        axios.get(api.get, {
            headers: {
                'Access-Control-Allow-Origin': '*'
            }
        })
            .then((response) => {
                response.data.data.forEach(function (el) {

                    let dateFormat = require('dateformat')
                    let now = new Date(el.created_at)

                    commit('NEW_TICKET', {
                        id: el.id,
                        name: el.name,
                        msg: el.body,
                        date: dateFormat(now, "dd/mm/yyyy à H:MM:ss")
                    })
                })
            })
}

ma​​in.js中初始化

import Vue from 'vue'
import vuetify from './plugins/vuetify'
import routes from './routes/router.js'
import App from './pages/layout/App'
import TicketStore from '@/store/TicketStore'

Vue.config.productionTip = false

new Vue({
    vuetify,
    created() {
        TicketStore.dispatch('getTicketsFromAPI')
    },
    render: h => h(App),
    router: routes,
}).$mount('#app')

即使我认为它不是最合适的,这种方式也有效

现在如果票不存在,我想停止导航;所以我在我的 routes.js

中创建了一个中间件

我第一次尝试:

    {
        path: '/ticket/:id', component: Ticket, name: 'ticket',

        beforeEnter: (to, from, next) => {
            const id = to.params.id
            const ticket = TicketStore.getters.getTicketById(id)
            /* eslint-disable no-console */
            console.log(id, ticket, to);
            /* eslint-enable no-console */
            if (ticket && ticket.id === id) {
                next()
            } else {
                next(false)
            }
        }
    },

这种方式可行,但如果我重新加载页面,const ticket 未定义

所以我搜索了;我遇到了多次讨论,从来没有真正帮助过我,比如这个 Vuex store is undefined in vue-router

我也试试这个

        beforeEnter: (to, from, next) => {
            const id = parseInt(to.params.id)
            /* eslint-disable no-console */
            console.log(TicketStore.state)
            TicketStore.state.tickets.forEach(function (el) {
                if (el.id === id) {
                    next()
                } else {
                    next(false)
                }
            })
            /* eslint-enable no-console */
        }

没有成功:这种方式行不通;但我在重新加载时在我的控制台中有票

我的目标是在票证不存在时停止导航,即使页面已重新加载

感谢您的帮助

【问题讨论】:

    标签: javascript vue.js vuex


    【解决方案1】:

    您应该在 store 中默认将 tickets 定义为一个空数组。 因为现在看起来您尝试从存储中获取一些数据,直到它不存在为止。

    【讨论】: