在 Vuex 商店中使用 vue-router
Posted
技术标签:
【中文标题】在 Vuex 商店中使用 vue-router【英文标题】:Using vue-router in Vuex store 【发布时间】:2017-12-18 19:46:57 【问题描述】:我想使用 vue-router 从 Vuex 商店路由到新组件。是否可以从 Vuex 商店访问路由器?我已经看到了一堆关于它的线程,但没有什么对我真正有用...下面的错误是我尝试使用路由器时得到的。
[Vue 警告]:挂载钩子错误:“TypeError: WEBPACK_IMPORTED_MODULE_2_vue_router.a.push 不是函数”
这是我的商店:
SENTENCE_TRACKER(commit, state)
let chosenSentence
if(state.currSent < state.res.length)
chosenSentence = state.res[state.currSent];
console.log(chosenSentence);
commit('CHINESE', chineseData:chosenSentence.chinese)
commit('ENGLISH', englishData:chosenSentence.english)
commit('PINYIN', pinyinData:chosenSentence.pinyin)
commit('AUDIO', audioData:chosenSentence.audio)
commit('WBW', wbwData:chosenSentence.wbw)
state.currSent++
else
// THIS IS WHERE I'D LIKE TO USE VUE-ROUTER
router.push(path:'/summary')
let arr = []
state.wbw.map(function(i)
arr.push('')
)
commit('WBW_STATE', wbwStateData: arr)
let shuffled = state.wbw.slice(), i, j, k;
for (i = shuffled.length; i; i--)
j = Math.floor(Math.random() * i);
k = shuffled[i - 1];
shuffled[i - 1] = shuffled[j];
shuffled[j] = k;
commit('SHUFFLED', shuffledData: shuffled)
,
谢谢!
【问题讨论】:
你能显示设置router
的代码吗?
【参考方案1】:
答案是我不必在商店中使用普通的this.$router
语法,而是这样做:router.push(name:'summary')
。谢谢!
【讨论】:
以上是关于在 Vuex 商店中使用 vue-router的主要内容,如果未能解决你的问题,请参考以下文章
如何使用 Nuxt 和 Jest 在 Vuex 商店测试中访问 this.app 和/或注入插件
如何从 Vuex 商店中删除 Firestore 快照侦听器