最近做的项目中,涉及vue router 路由操作,其操作方法不同,产生的行为亦不同。本文通过对比实验,对其行为进行实验对比及总结,避免混淆。
vue router的单页跳转的history模式,类似HTML5 history方式,两者使用的API类似。 

1、测试介绍

1.1、测试分两种跳转方式

a、单页 <-> 单页:单页内的跳转(通过vue router的方式跳转);
b、单页 <-> 普通页:单页到普通页面的跳转(或者通过href、window.location的方式跳单页)。

1.2、测试点

a、 router对应组件是否重新执行;
b、页面是否刷新。

1.3、用户操作

a、点击页内路由;
b、操作浏览器回退按钮。
 

2、测试

2.1、测试点用例设置

a、测试点a:组件是否重新执行
created() {
console.log('reload error ', testObj.pageName)
testObj.pageName = 'error'
}
在对应组件的created生命周期中输出信息,如果有信息输出,路由对应组件得到执行。
 
b、测试点b:是否刷新
在入口文件.html 中,设置变量var testObj = { pageName: 'init’},在跳转过程中,如果pageName的值非’init’,那么testObj变量在内存中得以保存,页面未刷新。
 

2.2、跳转方式用例设置

a、单页 <-> 单页
创建两个单页路由test1、test2,用于测试单页<—>单页的情况
          如下:
<router-link :to="{ name: 'test2'}">跳转</router-link>
<router-link :to="{ name: 'test1'}">跳转</router-link>
{
path: '/test',
component: App,
children: [{
path: 'my1',
component: test1,
name: 'test1',
meta: {
title: 'myTest1'
}
},
{
path: 'my2',
component: test2,
name: 'test2',
meta: {
title: 'myTest2'
}
}]
}
  预期:
a、router对应组件重新执行;
b、页面不刷新。
测试console结果:
reload 404  init
reload error  404
reload 404  error
reload error  404
结论:每次跳转,created生命周期中的代码都执行,说明组件重新执行,a点符合预期;created除第一刷新页面进来为’init’外,其他都为非’init’,说明跳转过程中变量存在内存中,页面未刷新,b点符合预期。
        
b、单页 <-> 普通页
<a href="http://10.10.11.182:8085/test/my2">外跳转</a>
window.location = 'http://10.10.11.182:8085/test/my2'
预期:页面直接刷新。
测试console结果:
        reload 404  init
// 外页
reload 404  init
结论:页面刷新,符合预期。
以上为操作页内路由跳转的测试结论,操作回退按钮[本实验使用chrome浏览器]的结论如下:
使用单页路由跳转形成的history(单页<->单页),操作浏览器回退按钮的行为与页内跳转的行为一致,未刷新页面,而是对应组件重新执行。
而通过href、window.location跳转的页面(单页<->普通页),操作浏览器回退按钮的行为与形成history行为一致,始终刷新页面。
 
总结:单页内跳转,产生的history变化,使得对应组件重新执行,但不刷新页面;但,使用href、window.location进行跳转,产生的history变化,将使得页面重新刷新。 
 
以上为浏览器在vue router 和 window.location、href 下产生的跳转行为表现,那么这些跳转背后的实质是什么呢?
了解其实质,就需要了解浏览器对window.location、href、history API 的设定,它们产生的原因和原理,下一篇将说明其背后的原理:window.history的跳转实质-HTML5 history API 解析

vue router的浏览器跳转行为的更多相关文章

  1. 10.vue router 带参数跳转

    vue router 带参数跳转 发送:this.$router.push({path:'/news',query:{id:row.id}}) 接收:var id=this.$route.query. ...

  2. Vue Router实现页面跳转拦截

    场景: 某些页面需要登录之后才可以访问,在页面跳转前做处理,如果要访问的页面A需要登录,则强制调到登录页,并且记录要访问的页面A的链接,在登录成功后自动跳转到页面A 1.在router下的index. ...

  3. vue router 跳转到新的窗口方法

    在CreateSendView2.vue 组件中的方法定义点击事件,vue router 跳转新的窗口通过采用如下的方法可以实现传递参数跳转相应的页面goEditor: function (index ...

  4. Vue Router路由守卫妙用:异步获取数据成功后再进行路由跳转并传递数据,失败则不进行跳转

    问题引入 试想这样一个业务场景: 在用户输入数据,点击提交按钮后,这时发起了ajax请求,如果请求成功, 则跳转到详情页面并展示详情数据,失败则不跳转到详情页面,只是在当前页面给出错误消息. 难点所在 ...

  5. Vue.js 2.x笔记:路由Vue Router(6)

    1. Vue Router简介与安装 1.1 Vue Router简介 Vue Router 是 Vue.js 官方的路由管理器.它和 Vue.js 的核心深度集成,构建单页面应用. Vue Rout ...

  6. Vue Router 路由实现原理

    一.概念 通过改变 URL,在不重新请求页面的情况下,更新页面视图. 二.实现方式 更新视图但不重新请求页面,是前端路由原理的核心之一,目前在浏览器环境中这一功能的实现主要有2种方式: 1.Hash  ...

  7. vue router.push(),router.replace(),router.go()和router.replace后需要返回两次的问题

    转载:https://www.cnblogs.com/lwwen/p/7245083.html https://blog.csdn.net/qq_15385627/article/details/83 ...

  8. 解决vue单页路由跳转后scrollTop的问题

    作为vue的初级使用者,在开发过程中遇到的坑太多了.在看页面的时候发现了页面滚动的问题,当一个页面滚动了,点击页面上的路由调到下一个页面时,跳转后的页面也是滚动的,滚动条并不是在页面的顶部 在我们写路 ...

  9. 深入浅出的webpack构建工具--webpack4+vue+router项目架构(十四)

    阅读目录 一:vue-router是什么? 二:vue-router的实现原理 三:vue-router使用及代码配置 四:理解vue设置路由导航的两种方法. 五:理解动态路由和命名视图 六:理解嵌套 ...

随机推荐

  1. GeoServer中配置GeoWebCache切片缓存目录

    war版的GeoServer中,默认情况下,GeoWebCache切片会缓存在C盘某目录下.该目录比较隐蔽,并且随着切片缓存的增多,所占空间也会越来越大,所以建议手动配置其切换缓存目录. 配置方式:在 ...

  2. LeetCode146:LRU Cache

    题目: Design and implement a data structure for Least Recently Used (LRU) cache. It should support the ...

  3. C#线程运用基础

    ThreadStart ts=new ThreadStart(a.f);//ThreadStart 是一个委托,用以关联a.f方法Thread th=new Thread (ts);//Thread是 ...

  4. 2D Polygons( Poygon) CGAL 4.13 -User Manual

    1 Introduction A polygon is a closed chain of edges. Several algorithms are available for polygons. ...

  5. Android学习之Fragment解析

    1.定义     Fragment中文解释是碎片的意思,主要用在大屏幕设备上,例如平板电脑上,支持更加动态和灵活的UI设计.Fragment在你的应用中相当于是一个模块化和可重用的组件,因为Fragm ...

  6. 面试题-一个列表向右移动k位

    def sort(lst,k): length = len(lst) left =lst[:-k] right =lst[-k:] lst.clear() lst.extend(right) lst. ...

  7. Sansa组件

    诉求 仿照admin组件,实现对表的URL分配管理. 实现思路 1.在settings.py文件中注册APP,注册示例为: 'app01.apps.App01Config', 'app02.apps. ...

  8. jenkins 配置。

    为了避免在jenkins操作过程中的权限问题. 将安装在/Users/Shared/jenkins目录下的卸载. sudo launchctl unload /Library/LaunchDaemon ...

  9. PHP 5.6 如何使用 CURL 上传文件

    以前我们通过 PHP 的 cURL 上传文件是,是使用“@+文件全路径”的来实现的: curl_setopt(ch, CURLOPT_POSTFIELDS, array( 'file' => ' ...

  10. Kafka集群副本分配算法解析

    副本分配算法如下: 将所有N Broker和待分配的i个Partition排序. 将第i个Partition分配到第(i mod n)个Broker上. 将第i个Partition的第j个副本分配到第 ...