利用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 相关文章推荐
JS控件autocomplete 0.11演示及下载 1月5日已更新
Jan 09 Javascript
js png图片(有含有透明)在IE6中为什么不透明了
Feb 07 Javascript
js 定时器setTimeout无法调用局部变量的解决办法
Nov 28 Javascript
Firefox下无法正常显示年份的解决方法
Sep 04 Javascript
深入分析下javascript中的[]()+!
Jul 07 Javascript
[原创]Javascript 实现广告后加载 可加载百度谷歌联盟广告
May 11 Javascript
JS 仿支付宝input文本输入框放大组件的实例
Nov 14 Javascript
微信小程序实现的动态设置导航栏标题功能示例
Jan 31 Javascript
JS实现计算小于非负数n的素数的数量算法示例
Feb 26 Javascript
小程序如何自主实现拦截器的示例代码
Nov 04 Javascript
详解Vue template 如何支持多个根结点
Feb 10 Javascript
简单了解JavaScript作用域
Jul 31 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
UCenter中的一个可逆加密函数authcode函数代码
2010/07/20 PHP
php设计模式 Facade(外观模式)
2011/06/26 PHP
PHP基础学习之流程控制的实现分析
2013/04/28 PHP
php反射应用示例
2014/02/25 PHP
php实现不通过扩展名准确判断文件类型的方法【finfo_file方法与二进制流】
2017/04/18 PHP
详解yii2使用多个数据库的案例
2017/06/16 PHP
js滚动条多种样式,推荐
2007/02/05 Javascript
跨域请求之jQuery的ajax jsonp的使用解惑
2011/10/09 Javascript
JQuery选择器特辑 详细小结
2012/05/14 Javascript
jquery 插件开发 extjs中的extend用法小结
2013/01/04 Javascript
jquery日历控件实现方法分享
2014/03/07 Javascript
JavaScript编程中window的location与history对象详解
2015/10/26 Javascript
jquery ajax分页插件的简单实现
2016/01/27 Javascript
TypeOf这些知识点你了解吗
2016/02/21 Javascript
Angular.js如何从PHP读取后台数据
2016/03/24 Javascript
基于jQuery实现中英文切换导航条效果
2016/09/18 Javascript
vue自定义指令实现v-tap插件
2016/11/03 Javascript
详解vue 数据传递的方法
2018/04/19 Javascript
[55:04]海涛DOTA2死魂复燃6.82版本介绍
2014/09/28 DOTA
[02:15]你好,这就是DOTA!
2015/08/05 DOTA
详解Python编程中基本的数学计算使用
2016/02/04 Python
浅析python中的迭代与迭代对象
2018/10/08 Python
Python中xml和json格式相互转换操作示例
2018/12/05 Python
Python3.6.2调用ffmpeg的方法
2019/01/10 Python
Css3新特性应用之视觉效果实例
2016/12/12 HTML / CSS
css 如何让背景图片拉伸填充避免重复显示
2013/07/11 HTML / CSS
字中字效果的实现【html5实例】
2016/05/03 HTML / CSS
华为python面试题
2016/05/03 面试题
个人优缺点自我评价
2014/01/27 职场文书
《值日生》教学反思
2014/02/17 职场文书
家长给学校的建议书
2014/05/15 职场文书
2014法院干警廉洁警示教育思想汇报
2014/09/13 职场文书
幼儿园毕业典礼家长致辞
2015/07/29 职场文书
校友会致辞
2015/07/30 职场文书
Python控制台输出俄罗斯方块移动和旋转功能
2021/04/18 Python
python机器学习Github已达8.9Kstars模型解释器LIME
2021/11/23 Python