如果我们采用SPA(单网页应用)的设计方式,服务器会把前端文件一次性发过来,前端通过监听url的改变,选择展示那些内容,也就是前端路由

一. 如何改变url但是页面不刷新?

方式一: 改变哈希值hash

比如,我们随便找一个网页

我们在浏览器控制台输入

发现网站的url有了些改变

查看network却没有任何请求

方式二 history模式的方法

(1). history.pushState()压栈式

比如,我们随便找一个网页

我们在浏览器控制台输入

history.pushState({},'','home')

发现网站的url有了些改变

查看network却没有任何请求

这种压栈式方法,可以使用浏览器返回上一页按钮弹栈,实际上是在调用

history.back()

也可以使用history.go() 操作栈

history.forward()  等价于  history.go(1)
history.back()  等价于  history.go(-1)

(2): history.replaceState()非压栈式

history.replaceState({},'','home')

二. 认识vue-router

1.安装 vue-router

cnpm install vue-router --save

我们也可以在用CLi项目创建时就选择好 vue-router 这样项目创建时会送我们一个hello world的例子,我们可以先体验一下

2.创建文件夹router,创建index.js

用来存放我们的路由配置

3.路由创建过程

首先,我们在index.js创建一个vuerouter并暴露

//1.导入VueRouter
import VueRouter from 'vue-router'
//2.导入Vue   (因为后面要用Vue.use())
import Vue from 'vue'//3.通过Vue.use安装一下插件
Vue.use(VueRouter)//4.创建路由对象
routes=[]const router = new VueRouter({routes
})//5.暴露路由对象
export default router

在main.js中,我们挂载这个vuerouter

import Vue from 'vue'
import App from './App.vue'
import router from './router'     //6.导入暴露的vuerouter (/index.js是默认,路径中省略了)Vue.config.productionTip = falsenew Vue({router,      //7. 将导入的router传给自己的router属性render: h => h(App),
}).$mount('#app')

4.配置映射关系

上面的模板中,routes=[], 我们没有配置映射关系, 现在我们来配置一下:

  • 第一步,导入页面组件
  • 第二步,创建映射关系
  • 第三步,在app.vue模板中(上级组件),添加router-link标签,这是一个触发url改变的入口
  • 第四步,在app.vue模板中(上级组件),添加router-view占位符标签,确定请求过来的内容的占位

在router/index.js中

import VueRouter from 'vue-router'
import Vue from 'vue'
import Home from '../components/Home'  //1. 导入第一个组件Home
import About from '../components/About' //1. 导入第二个组件AboutVue.use(VueRouter)
const routes = [{path: '/',       //2.添加映射关系component: Home},{path: '/about',  //2.添加映射关系component: About}
]const router = new VueRouter({routes
})export default router

在App.js中

<template><div id="app"><router-link to="/home">首页</router-link>   <!-- 3.使用路由 通过router-link标签,配置to属性提供链接目标,点击此标签会触发对应的url请求--><router-link to="/about">关于</router-link><!-- 3.使用路由 通过router-link标签,配置to属性提供链接目标,点击此标签会触发对应的url请求--><router-view></router-view><!-- 4.使用路由 通过router-view占位符标签,确定请求过来的内容的占位--></div>
</template><script>
export default {name: 'App',
}
</script><style scoped>
</style>

路由重定向:

const routes = [{path:'',redirect:'home'},
]

5.将默认的哈希方式改为history模式

vue默认是使用hash方式的,

我们可以给它改成history模式,

这需要,我们在router/index.js中创建VueRouter时传入另一个参数

const router = new VueRouter({routes,mode:'history'
})

此外我们在cli初始化项目时,也可以默认history模式

6.router-link 属性

  • to属性 :指向的url地址
  • tag属性: 默认是a标签,如果tag='button',则渲染成标签.此外还可以是 <li>等
  • replace属性: 采用非压栈式跳转,不可返回

同时,我们注意到,当某个标签被点击时,他的class会自动添加两个类:router-link-exact-active和router-link-active

有了这两个class,我们可以方便的写样式了

7. 不用router-link,通过代码修改路径 $router.push

上面的我们都是使用的 <router-link>来触发的url改变 有没有办法用普通的表单元素触发呢?

有的.比如一个button 我们绑定了他的单击事件 btnClick,则我们可以在方法里写:

每个组件都有一个全局对象叫$router,这个

btnClick(){this.$router.push('/home')
}

上面是压栈式,当然也有非压栈式

btnClick(){this.$router.replace('/home')
}

三. 动态路由 /:参数

很多时候我们的url可能是不固定的,访问的页面的具体信息也会随着url改变,这就称之为动态路由. 例如: 我们访问张三的资料 /user/zhangsan 李四的是 /user/lisi

注册动态路由的方法是 /:参数

我们注册映射关系时,这样注册

  {path:"/user/:userId",component:User}

我们触发url时这样触发

//在<router-link>上动态绑定
<router-link :to="'/user/'+userId">用户</router-link> //或者通过普通标签的事件:btnClick(){this.$router.push('/user/'+this.userId)}

那么url跳转后如何在先页面中拿到跳转的参数呢? 用$route

$route   :当前活跃路由 每个组件都有一个全局对象$route
一定要和$router区分开!!!!!

每个组件都有一个$route全局对象 (不是$router,少了一个r)

我们看到这个 对象里有一个属性params ,里面有一个键值对 就是我们想要的,这时我们制作一个计算属性放在我们想显示的位置就好了

  computed: {userId(){return this.$route.params.userId }},

四. 路由的懒加载

当我们打包时,我们的bundle.js会变得特别大,太大的bundle会使得加载变慢,从而出现浏览器空白.但其实即使是单页程序,也无需浪费这段时间,同时给用户不好的体验.我们完全可以使用懒加载,将刚开始用不到的代代码先不加载,等用户触发了相关路由时再加载

懒加载说白了就是不同的路由打包到不同的js里去

懒加载如何实现??

我们不要在一开始就import 而是在用到的地方,用箭头函数直接匿名import

    path: '/about',  //2.添加映射关系component: ()=>import('../components/About')},

这样,我们可以让首页之外的路由选择懒加载,都懒加载也可以

五. 路由的嵌套

为什么要路由嵌套?看下图:

我们想在home页面请求路由,把路径改为/home/news, 但是页面还是在home页,只不过绿框里的内容改为了news组件的内容

如何实现路由嵌套?

1.映射路由

因为还是在home页面,所以不能直接写路由映射,而是将路由映射嵌套在home的映射中

具体做法是,将子映射写在父映射的children属性里

  {path: '/home',       //这是home的映射component: Home,children:[           //它里面可以定义一个children,里面放子映射{path: '',       //添加默认子映射redirect:'news'},{path: 'news',                   //添加子映射关系 路径只写名字 newscomponent: ()=>import('../components/HomeNews')},{path: 'msgs',                   //添加子映射关系component: ()=>import('../components/HomeMsg')},]},

接下来我们在home.vue中确定显示位置 路径照实写

<template><div><h2>我是首页</h2><p>我是首页内容</p><router-link to="/home/news">看看新闻</router-link><router-link to="/home/msgs">看看消息</router-link><router-view></router-view></div>
</template><script>
export default {name: "Home"
};
</script><style scoped>
</style>

六. 传递参数的路由

传递参数的两种方式

  • 配置动态路由 /router/:参数
  • query类型的传递 请求路径还是/router 但是同时会传一个query,如: /router?id=123

如果只需要传递一个符号,则选择第一种,如果信息较多,传递第二种

第一种我们之前已经接触了,现在看

1. 如何用query传递参数

只需要在<router-link> 的to属性里绑定一个对象,对象有如下属性:

<router-link :to="{path:'/profile',     <--path属性还是路由链接-->query:{              <--query属性里面传入一个对象,对象里都是键值对--> id:'lili',age:20,gender:'girl'}}">Profile</router-link>

新页面里如何取?还是用之前用过的$route对象

this.$route.query

2.不用<router-link>怎么传query??

$router.push和$router.replace传入上述对象即可

  methods: {btnClick(){this.$router.push({path:'/profile',query:{name:"lili",age:18,gender:'girl'}})}}

七. keep-alive

一个页面如果跳转到了另一个页面,那么这个页面会被销毁,此时如果用户又返回这个页面,又需要重新加载.

keep-alive主要解决离开页面又返回时,页面需要重构的问题,这种重构很多时候都是没必要的

1. 如何使用keep-alive?

  • <router-view>其实也是个组件,如果它直接被包在<keep-alive>里面,所有涉及到的视图组件都会被缓存
  • <keep-alive>是定义在Vue中的内置组件,目的是为了避免重新渲染

例:我们想让home的两个次级路由的组件来回切换时不重新构建,可以给控制他们显示的<router-view>用<keep-alive>包起来

<template><div><h2>我是首页</h2><p>我是首页内容</p><router-link to="/home/news">看看新闻</router-link><router-link to="/home/msgs">看看消息</router-link><keep-alive><router-view></router-view></keep-alive></div>
</template><script>
export default {name: "Home"
};
</script><style>
</style>

2. 因为被keep-alive,子组件多了两个属性

被keep-alive的组件都会多两个属性 activated 和 deactivated,里面可以传入方法,当活跃/不活跃时调用

举例:

<template><div><h1>您有4条短消息</h1><ul><li>短消息1</li><li>短消息2</li><li>短消息3</li><li>短消息4</li></ul></div>
</template><script>
export default {name:"HomeMsg",activated() {console.log("我真活跃");},deactivated() {console.log("我不活跃了");},
}
</script><style></style>

3.<keep-alive> 的包含和例外

如果又4个标签,我们想其中3个keep-alive怎么办???

这时我们需要用keep-alive的属性

    <keep-alive exclude="HomeMsg,User">    这会排除这两个组件的keep-alive<router-view></router-view></keep-alive>

八. 导航守卫

有时我们需要监听页面跳转

比如,我们要监听页面跳转,跳转时,将我们的网站的title该为对应页面的名称

1.前置守卫

前置守卫是跳转前的守卫

我们可以在index.js里,给我们的router调用一个前置守卫(钩子)函数:router.beforeEach()

router.beforeEach((to,from,next)=>{   //这就是页面跳转过程document.title= to.meta.matched[0].title  //将页面标题改为了to路由的meta信息里的标题next()  // 必须调用next(),以维护链式
})

前提是to路由里有meta,如: meta(描述信息)

  {path:"/profile",component:()=>import('../components/Profile'),meta:{title:'档案'},},

为什么有个 .matched[0], 因为有时我们进入嵌套路由,比如, home/news,

但此时我们还想显示home的meta, 就可以通过这种方法找到它的第一级路由的meta

2.后置守卫

其实还有后置守卫(钩子):

router.afterEach(to,from)

后置守卫没有next

3.next有大用

  • next(): 进行管道中的下一个钩子。如果全部钩子执行完了,则导航的状态就是 confirmed (确认的)。
  • next(false): 中断当前的导航。如果浏览器的 URL 改变了 (可能是用户手动或者浏览器后退按钮),那么 URL 地址会重置到 from 路由对应的地址。
  • next('/') 或者 next({ path: '/' }): 跳转到一个不同的地址。当前的导航被中断,然后进行一个新的导航。你可以向 next 传递任意位置对象,且允许设置诸如 replace: truename: 'home' 之类的选项以及任何用在 router-link 的 to prop 或 router.push 中的选项。
  • next(error): (2.4.0+) 如果传入 next 的参数是一个 Error 实例,则导航会被终止且该错误会被传递给 router.onError() 注册过的回调。

4.路由独享守卫

你可以在路由配置上直接定义 beforeEnter 守卫:

const router = new VueRouter({routes: [{path: '/foo',component: Foo,beforeEnter: (to, from, next) => {// ...}}]
})

5.组件内守卫

你可以在路由组件内直接定义以下路由导航守卫:

const Foo = {template: `...`,beforeRouteEnter (to, from, next) {// 在渲染该组件的对应路由被 confirm 前调用// 不!能!获取组件实例 `this`// 因为当守卫执行前,组件实例还没被创建},beforeRouteUpdate (to, from, next) {// 在当前路由改变,但是该组件被复用时调用// 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,// 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。// 可以访问组件实例 `this`},beforeRouteLeave (to, from, next) {// 导航离开该组件的对应路由时调用// 可以访问组件实例 `this`}
}
beforeRouteEnter 守卫 不能 访问 this,因为守卫在导航确认前被调用,因此即将登场的新组件还没被创建。不过,你可以通过传一个回调给 next来访问组件实例。在导航被确认的时候执行回调,并且把组件实例作为回调方法的参数。beforeRouteEnter (to, from, next) {next(vm => {// 通过 `vm` 访问组件实例})
}
注意 beforeRouteEnter 是支持给 next 传递回调的唯一守卫。对于 beforeRouteUpdate 和 beforeRouteLeave 来说,this 已经可用了,所以不支持传递回调,因为没有必要了。beforeRouteUpdate (to, from, next) {// just use `this`this.name = to.params.namenext()
}
这个离开守卫通常用来禁止用户在还未保存修改前突然离开。该导航可以通过 next(false) 来取消。beforeRouteLeave (to, from, next) {const answer = window.confirm('Do you really want to leave? you have unsaved changes!')if (answer) {next()} else {next(false)}
}

js 刷新div_vue.js备忘记录(五) vue-router相关推荐

  1. Tmux命令使用备忘记录

    Tmux命令使用备忘记录 本博客只是用于记录Tmux最简单的命令,方便查阅. 注:Tmux当中的快捷键使用前需要先使用Ctrl+b 1. 新建会话 方式一 $ Tmux 此方式默认创建 <ses ...

  2. php 会员到期提醒_电脑上怎么在桌面加一个备忘记录提醒便签软件?

    电脑是大家日常工作中离不开的一款工具,使用电脑不仅可查询工作中所需的重要信息,还可以在电脑上记录一些工作备忘.工作任务等,为了避免忘记记录在电脑上备忘事项,大家可以选择一些能够在电脑桌面上查看且支持设 ...

  3. 随笔备忘记录-UI自动化测试-操作配置文件、封装公共类

    随便写点东西,有的是网上借鉴,有的是自己体会,总之都是根据自己的需求进行优化的一些东西,随笔备忘录 python3配置文件的增删改查等操作可以使用内置的ConfigParser模块,需要一个配置文件去 ...

  4. 随笔备忘记录-Appium_Python_Api文档

    随便写点东西,有的是网上借鉴,有的是自己体会,总之都是根据自己的需求进行优化的一些东西,随笔备忘 APP功能测试: 1.业务逻辑正确性测试:产品文档.隐形需求----编写测试用例 2.兼容性测试: ( ...

  5. 【Vue.js】Vue.js中常用的UI组件库和Vue Router

    1.Vue生态中常用的UI组件库 1. vant 介绍 轻量级.可靠的移动端 Vue 组件库 有赞前端团队出品 GitHub地址:https://github.com/youzan/vant 特性 拥 ...

  6. Vue.js 3.0 学习笔记(十一)Vue Router路由

    一.使用Vue Router 1.HTML页面使用路由 <!DOCTYPE html> <html> <head><meta charset="UT ...

  7. Excel拆分同一单元格的两行内容为两行(备忘记录)

    如何把一个单元格的两行内容改为二个单元格(每个单元格分别为修改之前的单元格的一行内容)? 如上图JIRA导出的数据中B列的单元格数据是两行,现在想拆分开,分别做成两列显示,以方便程序数据读取,那具体怎 ...

  8. PyTorch单机多卡训练(DDP-DistributedDataParallel的使用)备忘记录

    不做具体的原理分析和介绍(因为我也不咋懂),针对我实际修改可用的一个用法介绍,主要是模型训练入口主函数(main_multi_gpu.py)的四处修改. 以上的介绍来源https://zhuanlan ...

  9. 游戏音频技术备忘 (五)Wwise Unreal Engine 集成代码浅析 二

    AkAmbientSound类的实现 Unreal Engine提供了一个基本对象的构造器ObjectInitializer,一般来说用户创建的类总是拥有很多变量,因此 AkAmbientSound  ...

最新文章

  1. python在审计中的应用-【干货】Python自动化审计及实现
  2. Python 实现图片质量比较之PSNR和SSIM
  3. 有效使用计算机操作系统,有效地使用计算机操作系统.doc
  4. oracle修改窗口字体大小,jQuery之字体大小的设置方法
  5. Flutter中为图片设置波纹点击效果
  6. java MD5完整加解密工具类
  7. 适合记录日常工作的便签如何在电脑桌面上添加
  8. [技巧]深入了解强大的 ES6 「 ... 」 运算符
  9. 360安全桌面没有计算机了,360安全卫士桌面上的图标不见了怎么办
  10. 项目经理价值的最终体现
  11. KVM:将img文件转换成qcow2格式的镜像
  12. STM32F103标准库开发---目录
  13. excel中怎么拆分表格
  14. 计算机名和DNS域名的关系,域名、DNS、IP地址的对应关系
  15. 计算机小键盘如何启用,教你电脑开机时小键盘自动启用方法
  16. java win8 任务管理器_笔记本win8系统如何使用快捷键打开任务管理器
  17. STM32F05x加入RDP(LV1)后,Segger无法Unlock的解决办法
  18. 如果长期玩手机用计算机打字,长期玩手机带来的危害!来看看你中了几个
  19. python炫酷动画源代码_(数据科学学习手札85)Python+Kepler.gl轻松制作酷炫路径动画...
  20. 先有java后有天_Java基础第十四天总结——面向对象(下)

热门文章

  1. b站前端大佬_知乎大佬强烈热推的5个自学网站,看了几个月,月薪三千涨三万...
  2. export Oracle_sid =asm,单实例下oracle数据库从文件系统迁移到ASM上
  3. 安卓system镜像分区_玩机爱好者想要的PT分区到底是什么?可以使现有的安卓系统更快!...
  4. linux命令行聊天,Linux 下使用talk 进行聊天
  5. pyhton 面向对象(下)
  6. Linux环境下Flume的安装
  7. Kafka.net使用编程入门(一)
  8. Javascript Proxy对象 简介
  9. 2017-2018-1 20155229 《信息安全系统设计基础》第十四周学习总结
  10. c++ list sort