文档章节

Vue-Router的使用方法

p
 peakedness丶
发布于 2018/11/08 19:20
字数 1997
阅读 404
收藏 14

使用 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>

© 著作权归作者所有

共有 人打赏支持
p
粉丝 50
博文 126
码字总数 168578
作品 0
长沙
私信 提问
加载中

评论(1)

乱世当空
66666
Vue 全站缓存之 vue-router-then :前后页数据传递

连续预告了好几天,总算写到这篇了。 系列篇1:Vue 全站缓存之 keep-alive : 动态移除缓存 系列篇2:Vue 全站缓存二:如何设计全站缓存 本篇为系列篇3:Vue 全站缓存之 vue-router-then :前...

wanyaxing
2018/08/02
0
0
深入理解Vue router的部分高级用法

今天要介绍的是路由元信息,滚动行为以及路由懒加载这几个的使用方法。 1.路由元信息 什么是路由元信息,看看官网的解释,定义路由的时候可以配置 meta 字段可以匹配meta字段,那么我们该如何...

peakedness丶
2018/11/16
0
0
vue-router 实现分析

vue-router 是 Vue.js 官方的路由库,本着学习的目的,我对 vue-router 的源码进行了阅读和分析,分享出来给其他感兴趣的同学做个参考吧。 参考 源码:vuejs/vue-router v2.2.1 - github 文档...

luobotang
2017/03/25
0
0
Vue-router(一) HelloWorld

由于Vue在开发时对路由支持的不足,后来官方补充了vue-router插件,它在Vue的生态环境中非常重要,在实际开发中只要编写一个页面就会操作vue-router。要学习vue-router就要先知道这里的路由是...

阿刚ABC
2018/04/19
0
0
vue项目如何刷新当前页面的方法_vue.js_脚本之家

vue项目如何刷新当前页面的方法 更新时间:2018年05月18日 16:41:06 作者:敲代码的小老头 我要评论 这篇文章主要介绍了vue项目如何刷新当前页面的方法,小编觉得挺不错的,现在分享给大家,...

这篇文章主要介绍了vue项目如何刷新当前页面的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
2018/07/30
0
0

没有更多内容

加载失败,请刷新页面

加载更多

刚入职阿里,告诉你真实的职场生活,兼谈P6、P7、P8的等级

一:拿下offer的人,基本上都有什么特征? 二:为什么选择阿里? 三:阿里的工作氛围什么样? 四:阿里的薪资情况? 五:阿里的晋升空间有多大? 最近部门招聘,很多工程师,包括我在内都参与...

java知识分子
10分钟前
1
0

中国龙-扬科
13分钟前
0
0
深入理解定时器系列第一篇——理解setTimeout和setInterval

很长时间以来,定时器一直是javascript动画的核心技术。但是,关于定时器,人们通常只了解如何使用setTimeout()和setInterval(),对它们的内在运行机制并不理解,对于与预想不同的实际运行状...

Jack088
16分钟前
0
0
windows 安装nvm

1、nvw-windows的官网:https://github.com/coreybutler/nvm-windows/releases 2、选择nvm-setup.zip安装 3、配置环境变量 4、检查nvm是否安装成功 使用管理员权限打开一个命令行。输入nvm v...

灰白发
26分钟前
1
0
MySQL

慢日志查询作用 慢日志查询的主要功能就是,记录sql语句中超过设定的时间阈值的查询语句。例如,一条查询sql语句,我们设置的阈值为1s,当这条查询语句的执行时间超过了1s,则将被写入到慢查...

士兵7
28分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部