一、html页面中如何使用

1、引入 vue-router.js

2、安装插件

Vue.use(VueRouter)

3、创建路由对象

  var router = new VueRouter({

    // 4、配置路由

    routes:[{

      path:'/login',

      component:Login  //跳转到Login组件,所以先创建Login组件

    }]

  })

创建Login组件

var Login = {template:'<div>我是登陆页面</div>'}

5、将配置好的路由关联到vue实例中

new Vue({

  el:'',

  components:{

    'app':App

  },

  router:router//将上面步骤中创建的router对象引入进来,不引入报undifined 对象取不到mached错误

})

6、指定路由改变局部的位置

var  App={

  template:'

    <div>

      <router-view></router-view>  //留坑,待目标地址内容填充

    </div>

  '

}

二、路由内置组件router-link

用法 <rouoter-link to='/login'>登陆去</router-link>

如果路由规则中添加name属性,例如 {name:'login',path:'/login',component:Login}

则router-link可以通过名称找对象,获取path,用法   <rouoter-link :to="{name:'login'}">登陆去</router-link>

三、router参数获取

方式一 query方式

<rouoter-link to='/login' query={id:1}>登陆去</router-link>

路由配置路径为 (即路由规则) {name:'login',path:'/login',component:Login}

获取this.$route.query.id

生成的浏览器路径为 login?id=1

方式二 params方式

<rouoter-link to='/login' params={id:1}>登陆去</router-link>

路由配置路径也就是路由规则为  {name:'login',path:'/login/:id',component:Login}

获取方式this.$route.params.id

生成的浏览器路径为 login/id

两种方式相比较,params的方式需要在路由规则也就是路径中配置。

四、$router 与 $route的区别

两者都是vue-router的内置对象,$route是路由信息对象,只读对象。 $router是路由操作对象,只写对象。

五、嵌套路由

多个组件,按照不同锚点值部分,嵌入不同的坑。

即<router-view></router-view>中包含<router-view></router-view>

例子:将上面的Login组件使用router-view留坑

var Login = {template:'<div><router-view></router-view></div>'} 则对应的路由规则配置children属性,变为如下格式:

{name:'login',path:'/login',component:Login,children:[{name:'test',path:'/test',component:ChildrenCom}]}  //path可以写成/test也可以只写test,只是浏览器展示路径不同而已

路由其他介绍:

1、路由meta元数据

meta是对于路由规则是否需要验证权限的配置。 meta属性于name同级  meta:{ischecked:true}

2、路由钩子

权限控制的函数执行时期。路由匹配后,渲染到router-view之前,用法 router.beforeEach(function(to,from,next){})  //最后next()代表同行,不调用会卡住 next(false)代表取消导航  next({name:''})重定向

3、路由规则除了在上述new VueRouter是指定routers,还可以对象动态添加路由。 router.addRoutes([........])

4、路由规则可以配置重定向路径

{name:'login',path:'/login',redirect:{name:''}}

5、其他

a、跳到指定锚点  this.$router.push()

b、根据历史记录前进或者后退

this.$router.go(-1|1)

1代表前进  -1后退

注意:一个视图使用一个组件渲染,多个视图需要多个组件,所以需要在路由规则的component改完components

例如

<router-view ></router-view>

<router-view name='a'></router-view>

<router-view name='b'></router-view>

规则配置应该为:

{name:'shouye',path:'/',components:{default:Header,a:Body,b:Footer}}

:git上有开发的项目作为例子,有兴趣的可以下载学习。源代码已上传git:Git地址,也可以扫码加入QQ交流群

                                                                                

vue教程(五)--路由router介绍的更多相关文章

  1. vue教程3-01 路由、组件、bower包管理器使用

    vue教程3-01 路由.组件.包管理器 以下操作前提是 已经安装好node.js npm bower-> (前端)包管理器 下载: npm install bower -g 验证: bower ...

  2. vue工程化与路由router

    一.介绍     vue.js 是 目前 最火的前端框架,vue.js 兼具 angular.js 和 react.js 的优点,并剔除它们的缺点.并且提供了很多的周边配套工具 如vue-router ...

  3. vue初级学习--路由router的编写(resolve的使用)

    一.导语 最近在用vue仿写淘宝的商品详情页面以及加入购物车页面,若是成功了,分享给大家~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 二.正文 我先用控制台创建了vue项目demo(如 ...

  4. vue教程3-05 vue组件数据传递、父子组件数据获取,slot,router路由

    vue教程3-05 vue组件数据传递 一.vue默认情况下,子组件也没法访问父组件数据 <!DOCTYPE html> <html lang="en"> ...

  5. vue项目创建步骤 和 路由router知识点

    菜单快捷导航: vue项目创建 vue路由router知识点(路径参数.查询参数.命名路由.嵌套路由.命名视图.hash/history模式) 1.创建一个vue项目步骤 (windows环境下).创 ...

  6. Vue学习笔记-Vue.js-2.X 学习(七)===>脚手架Vue-CLI(路由Router)

    脚手架Vue-CLI(路由Router) 一 按装(通过新创建脚手架按装),如果在原来的脚手架上按装直接进图型化界面vue ui的插件按装. 二 使用(上面按装下面步骤自动会生成) 第一步:导入路由对 ...

  7. react router @4 和 vue路由 详解(六)vue怎么通过路由传参?

    完整版:https://www.cnblogs.com/yangyangxxb/p/10066650.html 8.vue怎么通过路由传参? a.通配符传参数 //在定义路由的时候 { path: ' ...

  8. react router @4 和 vue路由 详解(四)vue如何在路由里面定义一个子路由

    完整版:https://www.cnblogs.com/yangyangxxb/p/10066650.html 6.vue如何在路由里面定义一个子路由? 给父路由加一个 children:[] 参考我 ...

  9. vue教程3-06 vue路由嵌套(多层路由),路由其他信息

    多层嵌套: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

随机推荐

  1. linux-deployment

    官方 linux-deploymenthttp://doc.qt.io/qt-5/linux-deployment.html linuxdeployqthttps://github.com/probo ...

  2. 【spring boot】application.properties官方完整文档

    官方地址: https://docs.spring.io/spring-boot/docs/current-SNAPSHOT/reference/htmlsingle/ 进入搜索: Appendice ...

  3. python发送邮件554DT:SPM已解决

    说明:本例使用163邮箱 一.报错信息 使用SMTP发送邮件遇到以下报错: 554, b'DT:SPM 163 smtp10,DsCowACXeOtmjRRdsY8aCw--.21947S2 1561 ...

  4. 01 Django基础

    目录 一.什么是web框架? 框架,即framework,特指为解决一个开放性问题而设计的具有一定约束性的支撑结构,使用框架可以帮你快速开发特定的系统,简单地说,就是你用别人搭建好的舞台来做表演. 对 ...

  5. 推荐一个高效,易用功能强大的可视化API管理平台

    项目管理 提供基本的项目分组,项目管理,接口管理功能 接口管理 友好的接口文档,基于websocket的多人协作接口编辑功能和类postman测试工具,让多人协作成倍提升开发效率 MockServer ...

  6. MySQL解决存入数据库和取出数据库时间格式问题

    我们在往数据库里存数据时,时间格式正是我们想要的,然而取数据时去出现了这种情况 这明显不是我们想要的! 解决办法: 在我们配置mysql时添加一行代码: timezone:"08:00&qu ...

  7. Xmanager 5远程连接CentOS7图形化界面

    1.安装Xmanager 5下载链接:https://pan.baidu.com/s/1JwBk3UB4ErIDheivKv4-NA提取码:cw04 双击xmgr5_wm.exe进行安装 点击‘下一步 ...

  8. 【原创】Docker 搭建Maven私服nexus 3.17初始密码登录不上问题/admin登陆不上问题

    [原创-转载请说明出处] 博主最近在虚拟机中搭建Maven私服,遇到了一个关键问题就是nexus 3.17版本后初始密码不是admin/admin123. 对于nexus不熟悉的我弄了很长时间!!!心 ...

  9. Python中的函数及函数参数的使用

    函数:一个工具,随调随用 降级代码冗余 增加代码的复用性,提高开发效率,为了不成为cv战士 提高程序扩展性 函数有两个阶段:定义阶段,调用阶段. 定义时:只检查函数体内代码语法,不执行函数体内代码. ...

  10. 我把代码开源、托管到了GitHub、码云

    前言 学习了那么多知识点,写了那么多代码,一直都没有时间整理,之前都是新学一个知识点就在同一个工程项目中进行实践测试,导致这个工程越来越臃肿.越来越乱,连我自己都快看不懂了... 这段时间整理了部分代 ...