vue-router区分hash模式和history模式

总结:

hash模式是我们在url后面添加一个#xx触发事件。尽管浏览器没有请求服务器,但是页面状态和url已经关联起来了,这就是所谓的前端路由,单页应用的标配。

history模式下浏览器地址不规整(没有#),hash只能改变#后面的url片段,而history api则可以完全替换,但history刷新容易导致错误(刷新是实实在在地去请求服务器的。

 

众所周知,vue-router有两种模式,hash模式和history模式,这里来谈谈两者的区别。

hash模式

hash模式的工作原理是hashchange事件,可以在window监听hash的变化。我们在url后面随便添加一个#xx触发这个事件。

window.onhashchange = function(event){console.log(event.oldURL, event.newURL);let hash = location.hash.slice(1);document.body.style.color = hash;}

打印出来的结果如下:

可以看到里边有两个属性newURL和oldURL。可以通过模拟改变hsh的值,动态页面数据。

<div id="test" style="height: 500px;width: 500px;margin: 0 auto"></div>
<script>window.onhashchange = function(event){let hash = location.hash.slice(1);document.body.style.color = hash;document.getElementById('test').style.backgroundColor = hash}
</script>

 

尽管浏览器没有请求服务器,但是页面状态和url已经关联起来了,这就是所谓的前端路由,单页应用的标配。

 

 

history模式

把window.history对象打印出来可以看到里边提供的方法和记录长度

前进,后退,跳转操作方法:

history.go(-2);//后退两次
history.go(2);//前进两次
history.back(); //后退
hsitory.forward(); //前进

HTML5新增的API
 A)history.pushState(data, title [, url]):往历史记录堆栈顶部添加一条记录; data会在onpopstate事件触发时作为 参数传递过去;title为页面标题,当前所有浏览器都会 忽略此参数;url为页面地址,可选,缺省为当前页地址;
 B)history.replaceState(data, title [, url]) :更改当前的历史记录,参数同上; 
 C)history.state:用于存储以上方法的data数据,不同浏览器的读写权限不一样;
 D)window.onpopstate:响应pushState或replaceState的调用;有了这几个新的API,针对支持的浏览器,我们可以构建用户体验更好的应用了。就像刚提到的Facebook相册,虽然是AJAX的方式,但用户可以直接复 制页面地址分享给好友,

如果不想要很丑的 hash,我们可以用路由的 history 模式,这种模式充分利用 history.pushState API 来完成 URL 跳转而无须重新加载页面。

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

当你使用 history 模式时,URL 就像正常的 url,例如 http://www.yongcun.wang/tclass,也好看!

不过这种模式要玩好,还需要后台配置支持。因为我们的应用是个单页客户端应用,如果后台没有正确的配置,当用户在浏览器直接访问http://www.yongcun.wang/tclass就会返回 404,这就不好看了。

所以呢,你要在服务端增加一个覆盖所有情况的候选资源:如果 URL 匹配不到任何静态资源,则应该返回同一个 index.html 页面,这个页面就是你 app 依赖的页面。

给个警告,因为这么做以后,你的服务器就不再返回 404 错误页面,因为对于所有路径都会返回 index.html 文件。为了避免这种情况,你应该在 Vue 应用里面覆盖所有的路由情况,然后在给出一个 404 页面。

const router = new VueRouter({mode: 'history',routes: [{ path: '*', component: NotFoundComponent }]
})

 

出处:https://blog.csdn.net/wang1006008051/article/details/81805932 转载

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/553906.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue 打包前需修改的配置,解决白屏问题

vue-cli项目和electron-vue项目打包运行都有遇到的白屏问题&#xff0c;下面记录打包前需要确认的配置 第一&#xff1a; config文件夹下的index.js 中的文件中的 assetsPublicPath &#xff1a;‘/’ 改为’./’ 不然的话会是空白页&#xff0c;记住&#xff0c;是build那块。…

electron-vue解决打包错误、无法调用出开发者工具(亲测有效)

错误1&#xff1a; unresolved node modules vue... 或 not found modules..的错误 解决方式&#xff1a;依赖的模块错误&#xff0c;删除node_module文件夹后&#xff0c;尽量用npm install而不是淘宝镜像cnpm安装 错误2&#xff1a; Cannot create symlinks (on Windows hos…

JS中使用bignumber处理高精度小数运算

项目开发中发现精度丢失的问题&#xff0c;如0.10.2 0.30000000000000004的问题 解决方式&#xff1a;引用bignumber.js用于数字精度要求较高的计算。 1、安装或引用&#xff1a; 下载地址&#xff1a;https://github.com/MikeMcl/bignumber.js/releases 或 npm install big…

restful api接口设计

技术由来&#xff1a; 互联网早期&#xff0c;页面请求和并发量不高&#xff0c;且移动端未盛行时对接口要求不高&#xff0c;使用动态页面(jsp)就能满足绝大多数的使用需求。但是随着互联网和移动设备的发展&#xff0c;人们对Web应用的使用需求也增加&#xff0c;传统的动态…

vue-cli安装和使用

主要记录安装vue-cli制定版本和使用&#xff0c;注意vue-cli4创建项目命令和项目结构的改变 检查当前项目的vue-cli版本&#xff1a; vue -V 卸载当前版本&#xff1a; npm uninstall vue-cli -g 安装最新版本: npm install -g vue-cli 安装指定版本&#xff1a; npm in…

Apache 和 Tomcat 服务器的区别

Apache 和 Tomcat 都是web网络服务器&#xff0c;两者既有联系又有区别&#xff0c;在进行HTML、PHP、JSP、Perl等开发过程中&#xff0c;需要准确掌握其各自特点&#xff0c;选择最佳的服务器配置。 Apache是web服务器&#xff08;静态解析&#xff0c;如HTML&#xff09;&…

二进制、八进制、十六进制相互转换

一、十进制与二进制之间的转换 1、十进制转二进制 方法为&#xff1a;十进制数除2取余法&#xff0c;即十进制数除2&#xff0c;余数为权位上的数&#xff0c;得到的商值继续除2&#xff0c;依此步骤继续向下运算直到商为0为止。 &#xff08;具体用法如下图&#xff09; 2、二…

vue-cli3+与vue-cli2的区别和vue-cli 修改配置

vue-cli3是基于webpack4打造&#xff0c;vue-cli2是基于webpack3vue-cli3的设计原则是“0配置”&#xff0c;移除&#xff08;隐藏&#xff09;配置文件build和config等目录vue-cli3提供了vue ui 命令&#xff0c;提供了可视化配置vue-cli3移除了static文件夹&#xff0c;新增了…

electron打包vue-cli4项目的解决方案1(项目实测)

背景&#xff1a; 项目已通过vue-cli4框架开发并运行在nginx服务器上&#xff08;使用了nginx的反向代理&#xff09;&#xff0c;现需要将该项目转成桌面端应用程序&#xff0c;选择electron来实现。 设想2种解决方案&#xff1a; 1、使用electron-quick-start的loadURL方法…

IP 基础知识“全家桶”,45 张图一套带走!

转载自&#xff1a; https://mp.weixin.qq.com/s/kPjFeefB1Xsbc2bHz_Or1Q 前言 前段时间&#xff0c;有读者希望我写一篇关于 IP 分类地址、子网划分等的文章&#xff0c;他反馈常常混淆&#xff0c;摸不着头脑。 那么&#xff0c;说来就来&#xff01;而且要盘就盘全一点&am…

浅谈XSS攻击的那些事(附常用绕过姿势)

本文《浅谈XSS攻击的那些事&#xff08;附常用绕过姿势&#xff09;》 由一叶知安团队原创投稿安全脉搏首发&#xff0c;作者geek痕,安全脉搏独家首发表本文&#xff0c;如需要转载&#xff0c;请先联系安全脉搏授权&#xff1b;未经授权请勿转载。随着互联网的不断发展&#x…

了解与防御XSS攻击

一. XSS是什么 XSS攻击全称跨站脚本攻击&#xff08;Cross Site Scripting&#xff09;&#xff0c;是为不和层叠样式表(Cascading Style Sheets, CSS)的缩写混淆&#xff0c;故将跨站脚本攻击缩写为XSS&#xff0c;XSS是一种在web应用中的计算机安全漏洞&#xff0c;它允许恶意…

BS架构和CS架构的优缺点

1、CS、BS架构定义 CS&#xff08;Client/Server&#xff09;&#xff1a;客户端----服务器结构。C/S结构在技术上很成熟&#xff0c;它的主要特点是交互性强、具有安全的存取模式、网络通信量低、响应速度快、利于处理大量数据。因为客户端要负责绝大多数的业务逻辑和UI展示&a…

webService、webSocket、socket、http之间的区别

HTTP HTTP 是基于请求响应式的&#xff0c;即通信只能由客户端发起&#xff0c;服务端做出响应&#xff0c;无状态&#xff0c;无连接。 无状态&#xff1a;每次连接只处理一个请求&#xff0c;请求结束后断开连接。 无连接&#xff1a;对于事务处理没有记忆能力&#xff0c;服…

OSI七层模型传输过程的通俗理解

转自&#xff1a;http://bbs.clnchina.com.cn/thread-1250443-1-1.html 1.OSI七层模型划分。 从上到下依次是&#xff1a;应用层、表示层、会话层、传输层、网络层、数据链路层、物理层。 分层功能应用层网络服务与最终用户的一个接口&#xff08;可理解为人机交互界面&#xf…

软件开发之常见前端安全漏洞

原标题&#xff1a;软件开发之常见前端安全漏洞 软件开发完成后&#xff0c;在Web服务器在投入使用之前&#xff0c;应该确保服务器是相对安全地。保证服务器相对安全地前提是&#xff0c;要充分了解影响Web系统安全。 1、跨站脚本&#xff08;XSS&#xff09;漏洞跨站脚本攻击…

修改el-popover和el-select样式

如图el-popover弹框和el-select下拉项的的容器是div#app之外的&#xff0c;所以在scoped作用域内使用>>>或/deep/修改样式无效。虽然可以使用全局样式修改&#xff0c;但是会造成所有页面组件样式改变。 1、修改el-select选项样式的解决办法&#xff1a; Popper-appen…

vue项目使用electron打包成桌面应用

打包流程详情步骤&#xff1a; 1、准备工作&#xff1a; a、win7系统则确保node版本在v12以上&#xff0c;electron-builder对系统或版本有要求&#xff1b; b、项目路径不使用中文&#xff1b; c、使用淘宝镜像命令代替npm管理工具 npm install -g cnpm --registryhttps://…

Haar特征与积分图—概念解析

1. Adaboost方法的引入 1.1 Boosting方法的提出和发展 在了解Adaboost方法之前&#xff0c;先了解一下Boosting方法。 回答一个是与否的问题&#xff0c;随机猜测可以获得50%的正确率。如果一种方法能获得比随机猜测稍微高一点的正确率&#xff0c;则就可以称该得到这个方法的过…

在jsp中对mysql数据库分页的方法

针对分页&#xff0c;首先开发一个 PageBean 用来控制页面参数&#xff1a; Java代码 package com.longweir; //分页后的javaBean import java.sql.*; import com.longweir.util.*; public class PageBean { private int pageSize5; // 每页显示的记录…