【发布时间】:2018-07-15 07:27:12
【问题描述】:
我正在尝试使用 vue-router 将数据从一个组件重定向并传递到另一个组件。
在我的主要组件中,我有一个点击链接,我在其中调用 JavaScript 函数来进行路由。
<a href="javascript:void(0);" @click="switchComponent('ToolDetail')">click here</a>
methods: {
switchComponent(comp) {
this.$router.push({name:comp});
},
到目前为止,单击链接时路由本身会出现控制台错误。
未捕获的类型错误:无法读取未定义的属性“_router”
在我的 main.js 中,我已经导入了我的路由器-
import Vue from 'vue'
import App from './App.vue'
import router from 'vue-router'
Vue.config.productionTip = false
export const changeRoute = new Vue();
new Vue({
render: h => h(App)
}).$mount('#app')
Vue.use(router)
编辑: 根据@ittus 的回答,我做了这样的事情-
在我的 main.js-
import Vue from 'vue'
import App from './App.vue'
import VueRouter from 'vue-router'
Vue.use(VueRouter)
Vue.config.productionTip = false
new Vue({
render: h => h(App)
}).$mount('#app')
在我的HomeContent.vue-
<template>
...
..
<a href="javascript:void(0);" @click="switchComponent('ToolDetail')">click here</a>
...
..
</template>
<script>
import ToolDetail from './ToolDetail.vue';
import VueRouter from 'vue-router';
...
..
methods: {
switchComponent(comp) {
const routes = [
{ path: '/ToolDetail', component: ToolDetail, name: 'ToolDetail' }
]
const router = new VueRouter({
routes
})
router.push({name:'ToolDetail'});
},
...
..
</script>
现在,当我单击链接时,没有任何反应,也没有控制台错误。 请问有什么帮助吗?如果我可以提供更多详细信息,请告诉我。
【问题讨论】:
-
您确定 - HomeContent.vue 将其导出到 App.vue 文件中吗?同时确保您在 HomeContent.vue 中正确使用
export
标签: javascript vue.js vue-router