利用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代码编写需要注意的7个小细节小结
Sep 21 Javascript
基于IE下ul li 互相嵌套时的bug,排查,解决过程以及心得介绍
May 07 Javascript
jquery实现兼容浏览器的图片上传本地预览功能
Oct 14 Javascript
JavaScript返回当前会话cookie全部键值对照的方法
Apr 03 Javascript
JavaScript使用cookie实现记住账号密码功能
Apr 27 Javascript
深入浅出讲解ES6的解构
Aug 03 Javascript
js控制div层的叠加简单方法
Oct 15 Javascript
Websocket协议详解及简单实例代码
Dec 12 Javascript
js实现旋转木马效果
Mar 17 Javascript
基于node.js实现微信支付退款功能
Dec 19 Javascript
ExtJs使用自定义插件动态保存表头配置(隐藏或显示)
Sep 25 Javascript
从Node.js事件触发器到Vue自定义事件的深入讲解
Jun 26 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
PHP4之COOKIE支持详解
2006/10/09 PHP
php面向对象全攻略 (八)重载新的方法
2009/09/30 PHP
安装apache2.2.22配置php5.4(具体操作步骤)
2013/06/26 PHP
PHP递归删除目录几个代码实例
2014/04/21 PHP
ThinkPHP3.1新特性之对页面压缩输出的支持
2014/06/19 PHP
php while循环控制的简单实例
2016/05/30 PHP
Yii+upload实现AJAX上传图片的方法
2016/07/13 PHP
jquery简单体验
2007/01/10 Javascript
js 函数调用模式小结
2011/12/26 Javascript
JS判断客户端是手机还是PC的2个代码
2014/04/12 Javascript
JavaScript数组前面插入元素的方法
2015/04/06 Javascript
谈谈JSON对象和字符串之间的相互转换JSON.stringify(obj)和JSON.parse(string)
2015/10/01 Javascript
JS实现的网页背景闪电闪烁效果代码
2015/10/17 Javascript
最简单的JavaScript图片轮播代码(两种方法)
2015/12/18 Javascript
js实现动态创建的元素绑定事件
2016/07/19 Javascript
微信小程序 侧滑删除(左滑删除)
2017/05/23 Javascript
jQuery实现验证表单密码一致性及正则表达式验证邮箱、手机号的方法
2017/12/05 jQuery
使用Vue实现调用接口加载页面初始数据
2019/10/28 Javascript
[04:21]狐狸妈带你到现场 DOTA2 TI中国区预选赛线下赛路线指引
2014/05/22 DOTA
Python中比较特别的除法运算和幂运算介绍
2015/04/05 Python
python中global用法实例分析
2015/04/30 Python
Python FTP两个文件夹间的同步实例代码
2018/05/25 Python
Python+OpenCV图片局部区域像素值处理改进版详解
2019/01/23 Python
python遍历文件目录、批量处理同类文件
2019/08/31 Python
Python序列对象与String类型内置方法详解
2019/10/22 Python
利用python画出AUC曲线的实例
2020/02/28 Python
关于jupyter打开之后不能直接跳转到浏览器的解决方式
2020/04/13 Python
Python 爬虫的原理
2020/07/30 Python
通过实例解析python subprocess模块原理及用法
2020/10/10 Python
AmazeUI 折叠面板的实现代码
2020/08/17 HTML / CSS
北大自主招生自荐信
2013/10/19 职场文书
优秀员工个人的自我评价
2013/11/29 职场文书
2014年商场国庆节活动策划方案
2014/09/16 职场文书
单位一把手群众路线四风问题整改措施
2014/09/25 职场文书
2014年文艺部工作总结
2014/11/17 职场文书
自荐信范文
2019/05/20 职场文书