Vue Router

1.1 相关理解

1.1.1 vue-router 的理解

Vue 的一个插件库,专门用来实现 SPA 应用

1.1.2 对 SPA 应用的理解

  1. 单页 Web 应用(single page web application,SPA)
  2. 整个应用只有一个完整的页面
  3. 点击页面中的导航链接不会刷新页面,只会做页面的局部更新
  4. 数据需要通过 Ajax 请求获取

1.1.3 路由的理解

  1. 什么是路由

    1. 一个路由就是一组映射关系(key-value
      1. key 为路径, value 可能是 functioncomponent
  2. 路由分类

    1. 后端路由:
      1. 理解:valuefunction , 用于处理客户端提交的请求
      2. 工作过程:服务器接收到一个请求时,根据请求路径找到匹配的函数来处理请求,返回响应数据

    2.前端路由:

    1. 理解:valuecomponent,用于展示页面内容
    2. 工作过程:当浏览器的路径改变时,对应的组件就会显示。

1.2 基本路由

1.2.1 安装与使用

  1. 安装 vue-router,命令:npm install vue-router

  2. 应用插件:Vue.use(VueRouter)

  3. 编写 router 配置项:

    //引入VueRouter
    import VueRouter from 'vue-router'
    //引入Luyou 组件
    import About from '../components/About'
    import Home from '../components/Home'
    
    //创建router实例对象,去管理一组一组的路由规则
    const router = new VueRouter({
        routes:[
            {
                path:'/about',
                component:About
            },
            {
                path:'/home',
                component:Home
            }
        ]
    })
    
    //暴露router
    export default router
    
  4. 实现切换(active-class 可配置高亮样式)

     <router-link active-class="active" to="/about">About</router-link>
    
  5. 指定展示位置

    <router-view></router-view>
    
  6. 几个注意点:

    1. 路由组件通常存放在 pages 文件夹,一般组件通常存放在 components 文件夹
    2. 通过切换,“隐藏”了的路由组件,默认是被销毁掉的,需要的时候再去挂载
    3. 每个组件都有自己的 $route 属性,里面存储着自己的路由信息
    4. 整个应用只有一个 router,可以通过组件的 $router 属性获取到

1.2.2 总结

编写使用路由的 3 步

  1. 定义路由组件
  2. 注册路由
  3. 使用路由

1.3 嵌套(多级)路由

  1. 配置路由规则,使用 children 配置项:

    routes:[
         {
             path:'/about',
             component:About,
         },
         {
             path:'/home',
             component:Home,
             children:[ //通过children配置子级路由
                 {
                     path:'news', //此处一定不要写:/news
                     component:News
                 },
                 {
                     path:'message',//此处一定不要写:/message
                     component:Message
                 }
             ]
         }
       ]
    
  2. 跳转(要写完整路径):

    <router-link to="/home/news">News</router-link>
    

1.4 路由传参

1.4.1 路由的 query 参数

  1. 传递参数

    <!-- 跳转并携带query参数,to的字符串写法 -->
    <router-link :to="/home/message/detail?id=666&title=你好">跳转</router-link>
                 
    <!-- 跳转并携带query参数,to的对象写法 -->
    <router-link 
     :to="{
         path:'/home/message/detail',
         query:{
            id:666,
                title:'你好'
         }
     }"
    >跳转</router-link>
    
  2. 接收参数:

    $route.query.id
    $route.query.title
    

1.4.2 命名路由

  1. 作用:可以简化路由的跳转。

  2. 如何使用

    1. 给路由命名:

      {
        path:'/demo',
        component:Demo,
        children:[
            {
                path:'test',
                component:Test,
                children:[
                    {
                          name:'hello' //给路由命名
                        path:'welcome',
                        component:Hello,
                    }
                ]
            }
        ]
      }
      
    2. 简化跳转:

      <!--简化前,需要写完整的路径 -->
      <router-link to="/demo/test/welcome">跳转</router-link>
      
      <!--简化后,直接通过名字跳转 -->
      <router-link :to="{name:'hello'}">跳转</router-link>
      
      <!--简化写法配合传递参数 -->
      <router-link 
        :to="{
            name:'hello',
            query:{
               id:666,
                  title:'你好'
            }
        }"
      >跳转</router-link>
      

1.4.3 路由的 params 参数

  1. 配置路由,声明接收 params 参数

    {
     path:'/home',
     component:Home,
     children:[
         {
             path:'news',
             component:News
         },
         {
             component:Message,
             children:[
                 {
                     name:'xiangqing',
                     path:'detail/:id/:title', //使用占位符声明接收params参数
                     component:Detail
                 }
             ]
         }
     ]
    }
    
  2. 传递参数

    <!-- 跳转并携带params参数,to的字符串写法 -->
    <router-link :to="/home/message/detail/666/你好">跳转</router-link>
                 
    <!-- 跳转并携带params参数,to的对象写法 -->
    <router-link 
     :to="{
         name:'xiangqing',
         params:{
            id:666,
                title:'你好'
         }
     }"
    >跳转</router-link>
    

    特别注意:路由携带 params 参数时,若使用 to 的对象写法,则不能使用 path 配置项,必须使用 name 配置!

  3. 接收参数:

    $route.params.id
    $route.params.title
    

1.4.4 路由的 props 配置

作用:让路由组件更方便的收到参数

{
    name:'xiangqing',
    path:'detail/:id',
    component:Detail,

    //第一种写法:props值为对象,该对象中所有的key-value的组合最终都会通过props传给Detail组件
    // props:{a:900}

    //第二种写法:props值为布尔值,布尔值为true,则把路由收到的所有params参数通过props传给Detail组件
    // props:true
    
    //第三种写法:props值为函数,该函数返回的对象中每一组key-value都会通过props传给Detail组件
    props(route){
        return {
            id:route.query.id,
            title:route.query.title
        }
    }
}

1.4.5 <router-link>replace 属性

  1. 作用:控制路由跳转时操作浏览器历史记录的模式
  2. 浏览器的历史记录有两种写入方式:分别为 pushreplacepush 是追加历史记录,replace 是替换当前记录。路由跳转时候默认为 push
  3. 如何开启 replace 模式: <router-link replace .......>News</router-link>

1.5 编程式路由导航

  1. this.$router.push(path): 相当于点击路由链接(可以返回到当前路由界面)
  2. this.$router.replace(path): 用新路由替换当前路由(不可以返回到当前路由界面)
  3. this.$router.back(): 请求(返回)上一个记录路由
  4. this.$router.go(-1): 请求(返回)上一个记录路由
  5. this.$router.go( 1 ): 请求下一个记录路由
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,367评论 6 512
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,959评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,750评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,226评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,252评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,975评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,592评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,497评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,027评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,147评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,274评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,953评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,623评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,143评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,260评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,607评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,271评论 2 358

推荐阅读更多精彩内容

  • 简介 Vue Router[https://next.router.vuejs.org/] 是 Vue[https...
    Whyn阅读 2,335评论 0 1
  • 路由 理解: 一个路由(route)就是一组映射关系(key - value),多个路由需要路由器(router)...
    黑咔阅读 72评论 0 0
  • 路由介绍 Vue router是 Vue.js的官方路由管理器,用于构建单页面项目,在安装Vue-cli时,选择...
    听书先生阅读 568评论 0 1
  • SPA单页应用 传统的项目大多使用多页面结构,需要切换内容的时候我们往往会进行单个html文件的跳转,这个时候受网...
    视觉派Pie阅读 11,846评论 1 55
  • 写这个主要是为了帮助我自己的记忆并且以后回顾 如果不小心竟然有人看 有错误的地方欢迎指出,如果....你懂的! 初...
    城门小胡同阅读 1,727评论 0 1