vue -- 路由安装 入门使用

vue路由改写进阶–前置守卫验证是否登录

安装路由

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.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>

你可能感兴趣的:(vue,vue,react,app,centos,go)