前端路由以及浏览器回退,hash & history & location
一、前言
其实不止一次想监听浏览器的回退方法,比如
在 list.html 页滚动加载了几页列表,点到 detail.html 看详情,反回来时又得重新加载几页
H5 有背景音乐的,跳页就得重新放,体验实在不妙,等等
再其他就是体验上的优化了,虽然可以添加返回按钮,但手机的回退键还是很常用的。
再加上 ajax 的无刷新体验,单页面应用可谓是一大装逼利器。
二、前端路由的好处
(伪)换页面时还可以添加动画,丝滑流畅的操作体验实在不能更棒,另外相较后端路由,前端路由也算是减轻了服务区负荷...
也正基于此,根据不同 url 渲染不同视图这种路由的概念被提上台面,让渲染哪一个可以得到方便的管理。
三、前端路由的坏处
前端路由也是有利有弊,它的不足在于
1. 安全性,改改路由就能跳到某页面,肆意进入不同流程,想想还是有点瘆人的
2. 状态恢复,比如第一页添了表单,跳到第二页再返回,这些表单可能得清空之类的问题
四、实现前端路由
其实路由也就两步,实现 url 变化 & 捕捉变化进行不同的页面逻辑
1. 改变 url
location api 的 reload / replace 方法,修改 href / hash / search 等属性等,
history api 的 back / go 方法,以及比较新的 pushState / replaceState 方法...
改变 url 的方式太多了,
需要注意的是哪些是会刷新页面的,哪些是会改 url 但不刷新页面的...
2. 捕捉 url 变化
主要得靠 window 的事件 hashchange 和 popstate
用 setInterval 持续监听(每 100ms 比较 oldUrl 和 nowUrl)也不是不可以,但你也懂得性能是个好东西
注意:pushState / replaceState 不会触发 popstate 事件,其他是否触发问题你可以继续尝试
3. 简单的实现与封装
易懂的封装:
function Router() {
this.routes = {};
window.addEventListener('load', this.resolve.bind(this), false);
window.addEventListener('hashchange', this.resolve.bind(this), false);
}
Router.prototype.route = function(path, callback) {
this.routes[path] = callback || function(){};
}
Router.prototype.resolve = function() {
this.curHash = location.hash.slice(1) || '/';
typeof this.routes[this.curHash] === 'function' && this.routes[this.curHash]();
}
简单的案例:
<ul>
<li><a href="#blue">蓝色</a></li>
<li><a href="#yellow">黄色</a></li>
</ul>
<ul>
<li><a href="#red">红色</a></li>
</ul>
var router = new Router();
router.route('blue', function(){
document.body.style.background = 'lightblue';
});
router.route('yellow', function(){
document.body.style.background = 'yellow';
});
router.route('red', function(){
document.body.style.background = 'red';
});
DEMO1: https://foreverz133.github.io/demos/single/router.html
DEMO2: https://foreverz133.github.io/demos/single/history.html
五、其他
1. 不是所有页面都需要改变 url,因为它会牵扯到回退
2. 浏览器的回退在体验上对前端是道比较难回答的题,比如回退两页,不返回登录/支付等
3. 在转场之间加上动画,当然要完成这效果就得使用 click 和 transitionEnd 等事件了
4. 状态控制,最便捷(并非最佳)的办法是全局一个对象去保存这些状态,每次进行判断和初始化操作
5. 当然如果你会 ReactJS 等模块化渲染的话,路由还可以更厉害
6. 还要比往常遇到更多优化上的问题,比如资源加载/数据更新/操作流畅度等
7. 梳理逻辑和确定状态,这些前期的事远比书写更重要,不然你会被改死的,讲真!
本文所提路由还太狭隘,毕竟路由是前后端都有的东西,url 也仅仅是指向某资源,所以它还会涵盖处理数据/数据传递等更多方面
六、总结
单页面应用(SPA)对前端的要求成倍增加,对开发者来说其实是好事,
有挑战进度会更快,不过和后端/策划的契合度也要相应提高才行。
前端路由以及浏览器回退,hash & history & location的更多相关文章
- 【前端路由】Vue-router 中hash模式和history模式的区别
咱们今天说说VUE路由的hash模式与history模式的区别,这个也是面试常问的问题,不要小看这道题其实问到这里的时候那个面试官应该是个大牛,开发经验丰富,这个题其实就是考验你的开发经验是否属实. ...
- (转)浏览器对象window,history,location,navigator,screen
1.window对象:当前的浏览器窗口 window对象是BOM的核心,window对象指当前的浏览器窗口 所有JavaScript全局对象.函数以及变量均自动成为window对象的成员 全局变量是w ...
- vue开发关于微信授权登录以及路由mode模式(Hash|History)和手机平台(andriod|IOS)不得不说的故事
引用链接: https://segmentfault.com/a/1190000010753247?utm_source=tuicool&utm_medium=referral
- javascript基础修炼(6)——前端路由的基本原理
[造轮子]是笔者学习和理解一些较复杂的代码结构时的常用方法,它很慢,但是效果却胜过你读十几篇相关的文章.为已知的API方法自行编写实现,遇到自己无法复现的部分再有针对性地去查资料,最后当你再去学习官方 ...
- 前端路由原理之 hash 模式和 history 模式
什么是路由? 个人理解路由就是浏览器 URL 和页面内容的一种映射关系. 比如你看到我这篇博客,博客的链接是一个 URL,而 URL 对应的就是我这篇博客的网页内容,这二者之间的映射关系就是路由. 其 ...
- 前端路由两种模式:hash、history
随着 ajax 的使用越来越广泛,前端的页面逻辑开始变得越来越复杂,特别是spa的兴起,前端路由系统随之开始流行. 从用户的角度看,前端路由主要实现了两个功能(使用ajax更新页面状态的情况下): 记 ...
- 前端路由的两种模式: hash 模式和 history 模式
随着 ajax 的使用越来越广泛,前端的页面逻辑开始变得越来越复杂,特别是spa的兴起,前端路由系统随之开始流行. 从用户的角度看,前端路由主要实现了两个功能(使用ajax更新页面状态的情况下): 记 ...
- 前端路由的两种模式:hash(#)模式和history模式(转)
随着 ajax 的使用越来越广泛,前端的页面逻辑开始变得越来越复杂,特别是spa的兴起,前端路由系统随之开始流行. 从用户的角度看,前端路由主要实现了两个功能(使用ajax更新页面状态的情况下): 记 ...
- 前端路由hash、history原理及简单的实践下
阅读目录 一:什么是路由?前端有哪些路由?他们有哪些特性? 二:如何实现简单的hash路由? 三:如何实现简单的history路由? 四:hash和history路由一起实现 回到顶部 一:什么是路由 ...
随机推荐
- 【vue】---项目接口管理---【巷子】
一.前言 在vue开发中,会涉及到很多接口的处理,当项目足够大时,就需要定义规范统一的接口 假设后端的文档分成了以下几个模块 1.发现模块 2.个人信息模块 3.商品模块 4.评论模块 ...... ...
- opengl学习笔记(五):组合变换,绘制一个简单的太阳系
创建太阳系模型 描述的程序绘制一个简单的太阳系,其中有一颗行星和一颗太阳,用同一个函数绘制.需要使用glRotate*()函数让这颗行星绕太阳旋转,并且绕自身的轴旋转.还需要使用glTranslate ...
- 设计模式之——flyweight模式
flyweight模式,又叫做享元模式. 顾名思义,享元模式就是共享一个元素. 百度百科 解释为: 享元模式(英语:Flyweight Pattern)是一种软件设计模式.它使用共享物件,用来尽可能减 ...
- 【find -exec】查找并复制文件
find . -name *run_server* -type f -exec cp {} /tmp/ \;
- npm的用户名添加不上的原因
npm添加不上的错误e401 1.用cnpm提交,会提交的tao.org这个域名了,用npm提交试试 2.如果npm提交不上,那就查看配置文件配置中 registry=http://registry. ...
- 鼠标滑动到指定位置时div固定在头部
$(function(){ $(window).scroll(function () { if ($(window).scrollTop() > 253) { ...
- 微软官方出的各种dll丢失的修复工具
例如 :因为计算机中丢失 api-ms-win-crt-runtime-l1-1-0.dll.尝试重新安装该程序以解决此问题. 软件名称: Visual C++ Redistributable for ...
- 关于Ubuntu中Could not get lock /var/lib/dpkg/lock解决方案
在Ubuntu中,有时候运用sudo apt-get install 安装软件时,会出现一下的情况 E: Could not get lock /var/lib/dpkg/lock - open ( ...
- 机器学习理论基础学习1——频率派 VS 贝叶斯派
频率派 贝叶斯派 theta是个未知的常量,X是随机变量, theta是个随机变量,X是随机变量 MLE最大似然估计 MAE最大后验概率 统计机器学习,优化问题 1)建立模型.概率 2)定义损失函数 ...
- 机器学习理论基础学习18---高斯过程回归(GPR)
一.高斯(分布)过程(随机过程)是什么? 一维高斯分布 多维高斯分布 无限维高斯分布 高斯网络 高斯过程 简单的说,就是一系列关于连续域(时间或空间)的随机变量的联合,而且针对每一个时间或是空间点 ...