利用JS hash制作单页Web应用的方法详解


Posted in Javascript onOctober 10, 2017

前言

本文主要给大家介绍了关于利用JS hash制作单页Web应用的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

一、何为hash

这里要讲的hash(也叫哈希),指的是JS中location对象的hash属性,它返回的是URL中#后所跟的零个或多个字符。通常,我们可以通过location.hash的方式获取哈希值或设置哈希值。当然,我们也可以通过设置a标签的href属性来设置哈希值,当用户点击该a标签时即可改变页面的哈希值。

例如:

/** JS方式 **/
location.hash = 'hash'; //设置hash,该代码执行后URL后面增加“#hash”字符串
console.log(location.hash); //获取hash
/** HTML方式 **/
<a href="#hash" rel="external nofollow" >点击改变hash</a> <!-- 点击后URL后面增加“#hash”字符串 -->

值得注意的是,无论以何种方式改变哈希值,页面都不会刷新。

二、hash有何用处

1. 设置锚链接

通过设置锚链接(即为上述HTML方式),可使点击链接后页面根据元素id滑动到指定位置,即使页面跳转后也不例外。

2. 实现单页应用的制作

可以根据哈希值的变化来使相应元素显示或者隐藏,从而实现页面无刷新的单页切换。

三、何为单页Web应用

单页Web应用(single page web application,SPA),就是只有一张Web页面的应用,是加载单个HTML 页面并在用户与应用程序交互时动态更新该页面的Web应用程序。

以上是百度百科对单页应用(SPA)的解释,而使用hash可以非常方便的实现“页面”间的切换。

四、如何使用hash制作SPA

简单来说,就是先只显示第一个page,然后通过改变hash值来切换显示不同的page,前一个page隐藏。
这里写个简单的Demo演示一下吧:

1. 首先写好HTML结构

<article class="container">
 <section id="page1" class="page cur">第一页</section>
 <section id="page2" class="page">第二页</section>
 <section id="page3" class="page">第三页</section>
</article>
<nav id="nav" class="bottom-nav">
 <ul>
  <li>第一页</li>
  <li>第二页</li>
  <li>第三页</li>
 </ul>
</nav>

2. 然后为其设置CSS样式

.page{ display: none; /* 其他样式省略 */}
.page.cur{ display: block;}
/* 其他样式省略 */

3. 编写Javascript,实现单页切换

window.onload = function () {
 var nav = document.getElementById('nav');
 var navLi = nav.getElementsByTagName('li');
 for(var i = 0,len = navLi.length; i < len; i++){
  (function (i) { 
   navLi[i].onclick = function () { //点击nav中的li,改变hash值
    location.hash = 'page' + (i+1);
   }
  })(i);
 }
 location.hash = 'page1'; //每次页面重新加载时都回到page1
 window.onhashchange = function (e) { 
  //当hash变化时,执行hashchange事件,该事件具有oldURL和newURL两个事件属性,分别代表前一个URL和目前的URL
  var oldHash = e.oldURL.split('#')[1]; //取得前一个hash
  var newHash = e.newURL.split('#')[1]; //取得当前hash
  var oldPage = document.getElementById(oldHash);
  var newPage = document.getElementById(newHash);
  oldPage.classList.remove('cur'); //隐藏前一个page
  newPage.classList.add('cur');  //显示当前page
 };
}

这里有几个地方需要注意的是,IE并不兼容oldURL和newURL这两个属性,所以该方法有一定的局限性。当然,更好的方法是,一开始将hash值用变量存起来作为oldHash,具体方法如下:

/**** 前面代码省略 ****/
location.hash = 'page1';
var oldHash = location.hash;
window.onhashchange = function (e) {
 var newHash = location.hash;
 var oldPage = document.querySelector(oldHash);
 var newPage = document.querySelector(newHash);
 oldPage.classList.remove('cur');
 newPage.classList.add('cur');
 oldHash = newHash;
};

这里还有一个地方需要注意,就是classList在IE9及其以下浏览器不兼容,最好通过处理className属性的方式来实现相同的效果,此处便不再详述。

总结

以上就是这篇文章的全部内容了,当然,hash的作用或许远不止这些,以后如有遇到再同大家一起分享。希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
javascript Zifa FormValid 0.1表单验证 代码打包下载
Jun 08 Javascript
在浏览器窗口上添加遮罩层的方法
Nov 12 Javascript
jQuery建立一个按字母顺序排列的友好页面索引(兼容IE6/7/8)
Feb 26 Javascript
jquery实现漂浮在网页右侧的qq在线客服插件示例
May 13 Javascript
判断js对象是否拥有某一个属性的js代码
Aug 16 Javascript
jquery实现input输入框实时输入触发事件代码
Jan 28 Javascript
Node.js实现的简易网页抓取功能示例
Dec 05 Javascript
JavaScript 用fetch 实现异步下载文件功能
Jul 21 Javascript
JS简单获得节点元素的方法示例
Feb 10 Javascript
彻底弄懂 JavaScript 执行机制
Oct 23 Javascript
实例分析Array.from(arr)与[...arr]到底有何不同
Apr 09 Javascript
简单学习5种处理Vue.js异常的方法
Jun 17 Javascript
认识jQuery的Promise的具体使用方法
Oct 10 #jQuery
JavaScript如何获取到导航条中HTTP信息
Oct 10 #Javascript
使用Dropzone.js上传的示例代码
Oct 10 #Javascript
React中上传图片到七牛的示例代码
Oct 10 #Javascript
基于对象合并功能的实现示例
Oct 10 #Javascript
聊聊Vue.js的template编译的问题
Oct 09 #Javascript
Vue组件之全局组件与局部组件的使用详解
Oct 09 #Javascript
You might like
3个PHP多维数组转为一维数组的方法实例
2014/03/13 PHP
ThinkPHP实现二级循环读取的方法
2014/11/03 PHP
PHP解密Unicode及Escape加密字符串
2015/05/17 PHP
程序员的表白神器“520”大声喊出来
2016/05/20 PHP
PHP在linux上执行外部命令的方法
2017/02/06 PHP
PHP fprintf()函数用法讲解
2019/02/16 PHP
Javascript倒计时页面跳转实例小结
2013/09/11 Javascript
超简单JS二级、多级联动的简单实例
2014/02/18 Javascript
用js的document.write输出的广告无阻塞加载的方法
2014/06/05 Javascript
JavaScript汉诺塔问题解决方法
2015/04/21 Javascript
jQuery满屏焦点图左右滚动特效代码分享
2015/09/07 Javascript
微信小程序 video详解及简单实例
2017/01/16 Javascript
jquery.validate.js 多个相同name的处理方式
2017/07/10 jQuery
JS学习笔记之原型链和利用原型实现继承详解
2019/05/29 Javascript
vue 获取视频时长的实例代码
2019/08/20 Javascript
小程序中设置缓存过期的实现方法
2020/01/14 Javascript
[43:47]完美世界DOTA2联赛PWL S3 LBZS vs Phoenix 第一场 12.09
2020/12/11 DOTA
Python和perl实现批量对目录下电子书文件重命名的代码分享
2014/11/21 Python
Python基于tkinter模块实现的改名小工具示例
2017/07/27 Python
简单谈谈Python的pycurl模块
2018/04/07 Python
python 获取当天凌晨零点的时间戳方法
2018/05/22 Python
python实现黑客字幕雨效果
2018/06/21 Python
Python二进制文件读取并转换为浮点数详解
2019/06/25 Python
Python基于BeautifulSoup和requests实现的爬虫功能示例
2019/08/02 Python
Python如何实现动态数组
2019/11/02 Python
python函数装饰器之带参数的函数和带参数的装饰器用法示例
2019/11/06 Python
对CSS3选择器的研究(详解)
2016/09/16 HTML / CSS
英国办公用品商店:Office Outlet
2018/04/04 全球购物
股指期货心得体会
2014/09/13 职场文书
领导班子遵守党的政治纪律情况对照检查材料
2014/09/26 职场文书
爱护环境卫生倡议书
2015/04/29 职场文书
2015年挂职干部工作总结
2015/05/14 职场文书
2019年圣诞节祝福语集锦
2019/12/25 职场文书
如何用JavaScript实现一个数组惰性求值库
2021/05/05 Javascript
德劲DE1105机评
2022/04/05 无线电
Python爬虫网络请求之代理服务器和动态Cookies
2022/04/12 Python