P粉4360523642023-08-30 14:44:15
在setup()
中,元件實例不可用,因為元件尚未創建,所以在Composition API中沒有this
上下文可用於使用this.$store
。
我認為在setup()
中使store/router變數可用的唯一方法而不需要其他匯入是將它們作為全域變數附加到window
/globalThis
上(忽略全域變數的限制):
// router.js import { createRouter } from 'vue-router' export default createRouter({/*...*/}) // store.js import { createStore } from 'vuex' export default createStore({/*...*/}) // main.js import router from './router' import store from './store' window.$router = router window.$store = store
請注意,在Options API中和範本中,仍可使用$store
和$router
存取store和router,具體範例可參考Options API和模板中的範例,對於Vuex 4和Vue Router 4:
<template> <div>{{ $store.state.myProp }}</div> <button @click="$router.back()">返回</button> </template> <script> export default { mounted() { console.log(this.$store.state.myProp) console.log(this.$router.currentRoute) } } </script>