Vue-Router的使用方法

作者: 88b61f4ab233 | 来源:发表于2018-11-08 19:21 被阅读10次

    使用 Vue.js 做项目的时候,一个页面是由多个组件构成的,所以在跳转页面的时候,并不适合用传统的 href,于是 vue-router 应运而生。

    路由,其实就是指向的意思,当我点击页面上的home按钮时,页面中就要显示home的内容,如果点击页面上的about 按钮,页面中就要显示about 的内容。Home按钮 => home 内容, about按钮 => about 内容,也可以说是一种映射. 所以在页面上有两个部分,一个是点击部分,一个是点击之后,显示内容的部分。

    点击之后,怎么做到正确的对应,比如,我点击home 按钮,页面中怎么就正好能显示home的内容。这就要在js 文件中配置路由。

    官方文档: https://router.vuejs.org/zh-cn/essentials/getting-started.html

    Vue-Router的最简单使用

    1.先注册路由

    2.将路由注册到VM组件中

    3.定义组件

    4.页面定义跳转路径

    <!DOCTYPE html>
    <html>
      <head>
        <meta charset="UTF-8">
        <title></title>
        <script src="lib/vue.min.js"></script>
        <script src="lib/vue-router-3.0.1.js"></script>
        <style type="text/css">
        </style>//前端全栈学习交流圈:866109386
      </head>//面向1-3年经验前端开发人员
      <body>//帮助如破技术瓶颈,提升思维能力
         
        <div id="app">
          <!--
            由于Vue-router的hash匹配原则所以我们需要在原定义的路径上加一个#号
          -->
          <a href="#/login" rel="external nofollow" rel="external nofollow" >登录</a>
          <a href="#/register" rel="external nofollow" rel="external nofollow" >注册</a>
          <router-view></router-view>
        </div>
      </body>
      <script>
        var login={
          template:'<h1>登录组件</h1>'
        }
        var register={
          template:'<h1>注册组件</h1>'
        }
        var routerObj = new VueRouter({
          routes:[
          //此处的component只能使用组件对象,而不能使用注册的模板的名称
            {path:"/login",component:login},
            {path:"/register",component:register}
          ]
        })
        var vm = new Vue({
          el:'#app',
          data:{
          },
          methods:{
             
          },
          router:routerObj//将路由规则对象注册到VM实例上
        })
      </script>
    </html>
    

    使用Router-Link替代a标签
    这么做主要是为了去掉a标签中的为了匹配hash地址的“#”,如下

    <!DOCTYPE html>
    <html>
      <head>
        <meta charset="UTF-8">
        <title></title>
        <script src="lib/vue.min.js"></script>
        <script src="lib/vue-router-3.0.1.js"></script>
        <style type="text/css">
        </style>
      </head>
      <body>
         
        <div id="app">
          <!--
            由于Vue-router的hash匹配原则所以我们需要在原定义的路径上加一个#号
          -->
    <!--      <a href="#/login" rel="external nofollow" rel="external nofollow" >登录</a>
          <a href="#/register" rel="external nofollow" rel="external nofollow" >注册</a>-->
          <router-link to="/login" tag="span">登录</router-link>
          <router-link to="/register">注册</router-link>
          <router-view></router-view>
        </div>//前端全栈学习交流圈:866109386
      </body>//面向1-3年经验前端开发人员
      <script>//帮助突破技术瓶颈,提升思维能力
        var login={
          template:'<h1>登录组件</h1>'
        }
        var register={
          template:'<h1>注册组件</h1>'
        }
        var routerObj = new VueRouter({
          routes:[
          //此处的component只能使用组件对象,而不能使用注册的模板的名称
            {path:"/login",component:login},
            {path:"/register",component:register}
          ]
        })
        var vm = new Vue({
          el:'#app',
          data:{
          },
          methods:{
             
          },
          router:routerObj//将路由规则对象注册到VM实例上
        })
      </script>
    </html>
    

    同时,我们还可以利用tag标签来渲染router-link元素,router-link默认渲染为a链接元素,使用tag标签可以渲染其他元素,上述代码中渲染为span元素了。无论渲染成什么元素,都依然与a连接一样拥有跳转的点击事件

    重定向技术以及默认路径
    默认路径

    我们可以使用默认路径的方式指定根路径,只需要在上述路由定义的方式中加入默认路径即可

    var routerObj = new VueRouter({
      routes:[
      //此处的component只能使用组件对象,而不能使用注册的模板的名称
        {path:"/",component:login},
        {path:"/login",component:login},
        {path:"/register",component:register}
      ]
    })
    

    重定向方式指定默认路径
    同样的使用一行代码即可直接重定向到login路径下,相比上述的默认路径,此方式在url的展示上更为明显

    var routerObj = new VueRouter({
      routes:[
      //此处的component只能使用组件对象,而不能使用注册的模板的名称
        {path:"/",redirect:"/login"},
        {path:"/login",component:login},
        {path:"/register",component:register}
      ]
    })
    

    路由选中之后高亮设置
    使用默认类设置为高亮
    Vue为router-link内置了一个连接点击之后高亮的类router-link-active,即可以在自己的style中设置

    <style type="text/css">
      .router-link-active{
        color: red;
        font-weight: 800;
        font-style: italic;
        font-size: 30px;
      }
    </style>
    

    使用自定义类名
    当我们想使用第三方定义的选中样式,或者是自己想定义更为简洁的样式,可以使用linkActiveClass来定义,即在路由初始化时指定类名,在指定样式时再自定义样式

    var routerObj = new VueRouter({
      routes:[
      //此处的component只能使用组件对象,而不能使用注册的模板的名称
        {path:"/",redirect:"/login"},
        {path:"/login",component:login},
        {path:"/register",component:register}
      ],
      linkActiveClass:'myactive'
    })
    

    指定样式

    <style type="text/css">
      .router-link-active,.myactive{
        color: red;
        font-weight: 800;
        font-style: italic;
        font-size: 30px;
      }
    </style>
    

    路由传参
    使用query方式传递参数
    首先我们再设置路由链接是指定参数

    <router-link to="/login?id=10&name=zhao">登录</router-link>
    且可以指定并获取多个参数,主要是再定义的组件对象内部使用created方法来获得
    
    var login={
      template:'<h1>登录组件---{{$route.query.id}}--{{$route.query.name}}</h1>',
      created(){
        console.log(this.$route.query.id)
      }
    }
    

    使用params方式传递参数
    首先我们在路由定义的时候采用:定义params参数

    var routerObj = new VueRouter({
      routes:[
      //此处的component只能使用组件对象,而不能使用注册的模板的名称
        {path:"/login/:id/:name",component:login},
        {path:"/register",component:register}
      ],
    })
    

    在实际使用过程中如何传递

    <router-link to="/login/10/zhao">登录</router-link>
       <router-link to="/register">注册</router-link>
       <router-view></router-view>
    

    在组件中使用

    var login={
      template:'<h1>登录组件---{{$route.params.id}}</h1>',
      created(){
        console.log(this.$route.params.id)
      }
    }
    

    路由嵌套的实现

    <!DOCTYPE html>
    <html>
      <head>
        <meta charset="UTF-8">
        <title></title>
        <script src="lib/vue-2.4.0.js"></script>
        <script src="lib/vue-router-3.0.1.js"></script>
        <style type="text/css">
     
        </style>//前端学习交流圈:866109386
      </head>//面向1-3年经验前端人员
      <body>//帮助突破技术瓶颈,提升思维能力
     <div id="app">
     
      <router-link to="/account">Account</router-link>
     
      <router-view></router-view>
     
     </div>
     
     <template id="tmpl">
      <div>
       <h1>这是 Account 组件</h1>
     
       <router-link to="/account/login">登录</router-link>
       <router-link to="/account/register">注册</router-link>
     
       <router-view></router-view>
      </div>
     </template>
     
     <script>
     
      // 组件的模板对象
      var account = {
       template: '#tmpl'
      }
     
      var login = {
       template: '<h3>登录</h3>'
      }
     
      var register = {
       template: '<h3>注册</h3>'
      }
     
      var router = new VueRouter({
       routes: [
        {
         path: '/account',
         component: account,
         // 使用 children 属性,实现子路由,同时,子路由的 path 前面,不要带 / ,否则永远以根路径开始请求,这样不方便我们用户去理解URL地址
         children: [
          { path: 'login', component: login },
          { path: 'register', component: register }
         ]
        }
    }
       ]
      })
     
      // 创建 Vue 实例,得到 ViewModel
      var vm = new Vue({
       el: '#app',
       data: {},
       methods: {},
       router
      });
     </script>
    </body>
    </html>
    

    主要是由children属性来实现的,上述代码中由三个易错点

    1.定义路由时,子路由没有‘/'
    2.在父组件中定义子组件要写子组件的全路径

    3.在父组件中定义组件同样要加入router-view元素

    案例:路由命名视图实现经典布局
    命名视图在定义路由时使用components属性(注意不是component)来定义:

    var routerObj = new VueRouter({
      routes:[
      //此处的component只能使用组件对象,而不能使用注册的模板的名称
        {path:"/",components:{
          default:header,
          left:leftBox,
          main:mainBox
        }},
      ]
    })
    

    几个组件分别定义如下

    var header={
      template:'<h1 class="header">头部区域</h1>'
    }
    var leftBox={
      template:'<h1 class=left>左部菜单区域</h1>'
    }
    var mainBox={
      template:'<h1 class="main">主体内容区域</h1>'
    }
    

    我们在页面上使用上述命名视图时使用router-view的name属性来定义

    <div id="app">
      <router-view></router-view>
      <div id="container">
        <router-view name="left"></router-view>
        <router-view name="main"></router-view>
      </div>
     
    </div>
    

    未使用命名属t性name设置视图组件的将采用default命名视图

    设置一下样式

    style type="text/css">
      html,body{
        margin: 0;
        padding: 0;
      }
      h1{
        margin: 0;
        padding: 0;
        font-size: 16px;
      }
      .header{
        background-color: #6495ED;
        height: 200px;
      }
       
      #container{
        display: flex;
        height: 600px;
      }
      .left{
        flex: 2;
        background-color: #0000FF;
      }
      .main{
        flex: 8;
        background-color: #8A2BE2;
      }
    </style>
    

    相关文章

      网友评论

        本文标题:Vue-Router的使用方法

        本文链接:https://www.haomeiwen.com/subject/bifgxqtx.html