安装路由
cnpm install --save vue-router
配置路由
创建src/router/index.js目录,输入以下代码
import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '../components/HelloWorld'
Vue.use(Router);
export default new Router({
routes:[
{
path:"/",
component:HelloWorld
}
]
});
在main.js中引入路由
import Vue from 'vue'
import App from './App'
import router from './router'
Vue.config.productionTip = false
new Vue({
el: '#app',
router,
components: {
App },
template: '<App/>'
})
在App.vue中使用路由视图
<template>
<div id="app">
<router-view></router-view>
</div>
</template>
<script>
export default {
name: 'App'
}
</script>
创建新的组件 ***.vue
<template>
<div>
Home Page
</div>
</template>
修改路由(src/router/index.js)
import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '../components/HelloWorld'
import Home from '../components/***.vue'
Vue.use(Router);
export default new Router({
routes:[
{
path:"/",
component:HelloWorld
},{
path:"/***",
component:***
}
]
});
页面跳转
发送值
<template>
<div class="hello">
<button @click="doclick()">无参数跳转界面</button><br>
<input type="text" v-model="msg"><br>
<button @click="doclickcanshu(msg)">有参数跳转界面</button>
</div>
</template>
<script>
export default {
name: 'HelloWorld',
data(){
return {
msg:""
}
},methods:{
doclick(){
this.$router.push({
path: 'helloworld1' });
},doclickcanshu(val){
this.$router.push({
name: 'helloworld1' , params: {
item: val }});
}
}
}
</script>
接收值
<template>
<div>
我是哈哈
<p v-if="!msg">没有人传给我值</p>
<p v-else>{
{
msg}}</p>
</div>
</template>>
<script>
export default {
name: 'App',
data(){
return {
msg:""
}
},
created() {
this.msg = this.$route.params.item;
console.log(this.$route.params.item);
},
}
</script>