History是有趣的,不是吗?在之前的HT ML 版本中,我们对浏览 历史记录 的操作非常有限。我们可以来回使用可以使用的方法,但这就是一切我们能做的了。
但是, 利用 html 5 的History API,我们可以更好的控制浏览器的历史记录了。例如:我们可以添加一条记录到历史记录的列表中, 或者 在没有刷新时,可以更新地址栏的URL。
为什么介绍History API ?
在这篇 文章 中,我们将 了解 HTML 5中History API的来 源 。在此之前,我们经常使用散列值来 改变 页面内容 ,特别是那些对页面特别 重要 的内容。因为没有刷新,所以对于 单页面应用 ,改变其URL是不可能的。此外,当你改变URL的散列值值,它对浏览器的历史记录没有任何影响。
然后,现在对于HTML 5的History API来说,这些都是可以轻易实现的,但是由于单页面应用没必要使用散列值,它可能需要额外的开发脚本。它也允许我们用一种对SEO友好的方式建立新应用。此外,它能减少 带宽 ,但是该怎么证明呢?
在文章中,我将用History API开发一个单页应用来证明上述的问题。
这也意味着我必须先在首页加载必要的资源。现在 开始 ,页面仅仅加载需要的内容。换句话说,应用并不是一开始就加载了全部的内容,在请求第二个应用内容时,才会被加载。
注意,您需要执行一些 服务器 端编码只提供部分资源,而不是完整的页面内容。
浏览器支持
在写这篇文章的时候,各主流浏览器对History API的支持是非常不错的,可以点击此处查看其支持情况,这个链接会告诉你支持的浏览器,并使用之前,总有良好的实践来检测支持的特定功能。
为了用变成方式确定浏览器 是否 支持这个API,可以用下面的一行代码 检验 :
&nbs p;
XM L/HTML Code 复制内容到剪贴板
return !!(window.history && history.push stat e);
此外,我建议参考一下这篇文章: detect Support for VAR ious HTML5 Features.(ps:后续会 翻译 )
如果你是用的现代浏览器,可以用下面的代码:
XML/HTML Code 复制内容到剪贴板
if (Modernizr.history) { // History API Supported }
如果你的浏览器不支持History API,可以使用history.js代替。
使用History
HTML 5提供了两个新方法:
1、history.pushState(); 2、history.replaceState();
两种方法都允许我们添加和更新历史记录,它们的工作原理相同并且可以添加数量相同的参数。除了方法之外,还有popstate事件。 在后 文中将介绍怎么使用和什么时候使用popstate事件。
pushState()和replaceState()参数一样,参数说明如下:
1、state:存储JSON字符串,可以用 在P opstate事件中。
2、t IT le:现在大多数浏览器不支持或者忽略这个参数,最好用null代替
3、url:任意有效的URL,用于更新浏览器的地址栏,并不在乎URL是否已经存在地址列表中。更重要的是,它不会重新加载页面。
两个方法的主要区别就是:pushState()是在history栈中添加一个新的条目,replaceState()是替换当前的记录值。如果你还对这个有迷惑,就用一些示例来证明这个区别。
假设我们有两个栈块,一个标记为1,另一个标记为2,你有第三个栈块,标记为3。当执行pushState()时,栈块3将被添加到已经存在的栈中,因此,栈就有3个块栈了。
同样的假设情景下,当执行replaceState()时,将在块2的堆栈和放置块3。所以history的记录条数不变,也就是说,pushState()会让history的数量加1.
比较结果如下图:
到此,为了控制浏览器的历史记录,我们忽略了pushState()和replaceState()的事件。但是假设浏览器统计了许多的不良记录,用户可能会被重定向到这些页面,或许也不会。在这种情况下,当用户使用浏览器的前进和后退导航按钮时就会产生意外的问题。
尽管当我们使用pushState()和replaceState()进行处理时,期待popstate事件被触发。但实际上,情况并不是这样。相反,当你浏览会话历史记录时,不管你是点击前进或者后退按钮,还是使用history.go和history.back方法,popstate都会被触发。
In webkit br owsers, a popstate event would be trigge red after document’s onload event, but Firefox and IE do not have this behavior.(在WebKit浏览器中,popstate事件在document的onload事件后触发,Firefox和IE没有这种行为)。
Demo示例
HTML:
XML/HTML Code 复制内容到剪贴板
< div class = "cont ai ner" > < div class = "row" > < ul class = "nav na vb ar-nav" > < li > < a hr ef = "home.html" class = "historyAPI" > Home </ a > </ li > < li > < a href = "about.html" class = "historyAPI" > About </ a > </ li > < li > < a href = "contact.html" class = "historyAPI" > Contact </ a > </ li > </ ul > </ div > < div class = "row" > < div class = "col-md-6" > < div class = "well" > Click on Links above to see history API usage using < code > pushState </ code >   ;m ethod. </ div > </ div > < div class = "row" > < div class = "jumbotron" id = "contentHolder" > < h1 > Home! </ h1 > < p > Lorem Ipsum is simply dummy text of the < span style = "width: auto; h ei ght: auto; float: none;" id = "5_nwp" > < a style = "text-decoration: none;" mpid = "5" t arg et = "_blank" href = "http://c PR o.baidu .COM /cpro/ui/uijs.php?adclass=0& am p;app_id=0&c=news& CF =1001&ch=0&di=128&fv=0&is_app=0&jk=f7cb547a6e640f0a&k=printing&k0=printing&kdi0=0&luki=5&n=10&p=baidu&q=06011078_cpr&rb=0&rs=1&seller_id=1&sid=a0f646e7a54cbf7&ssp2=1&stid=0&t=tpclicked3_hc&tu=u1922429&u=http%3A%2F%2Fwww%2Eadmi n1 0000%2Ecom%2Fdocument%2F5 360 %2Ehtml&urlid=0" id = "5_nwl" > < span style = "color: # 0000ff;font- Size: 14px;width:auto;height:auto;float:none;" > printing </ span > </ a > </ span > and ty PE setting industry. </ p > </ div > </ div > </ div > </ div >
JavaScript:
XML/HTML Code 复制内容到剪贴板
< script type ="text/ < span style=" width : auto; height: auto; float: none;" id = "1_nwp" > < a style = "text-decoration: none;" mpid = "1" target = "_blank" href = "http://cpro.baidu测试数据/cpro/ui/uijs.php?adclass=0&app_id=0&c=news&cf=1001&ch=0&di=128&fv=0&is_app=0&jk=f7cb547a6e640f0a&k=javascript&k0=javascript&kdi0=0&luki=8&n=10&p=baidu&q=06011078_cpr&rb=0&rs=1&seller_id=1&sid=a0f646e7a54cbf7&ssp2=1&stid=0&t=tpclicked3_hc&tu=u1922429&u=http%3A%2F%2Fwww%2Eadmin10000%2Ecom%2Fdocument%2F5360%2Ehtml&urlid=0" id = "1_nwl" > < span style = "color:#0000ff;font -s ize:14px;width:auto;height:auto;float:none;" > javascript </ span > </ a > </ span > " > jq uery('document').ready(function(){ jQuery('.historyAPI').on('click', function(e){ e.p rev entDefault(); var href = $(this).attr('href'); // Getting Content getContent(href, true); jQuery('.historyAPI').removeClass('active'); $(this). < span style = "width: auto; height: auto; float: none;" id = "2_nwp" > < a style = "text-decoration: none;" mpid = "2" target = "_blank" href = "http://cpro.baidu测试数据/cpro/ui/uijs.php?adclass=0&app_id=0&c=news&cf=1001&ch=0&di=128&fv=0&is_app=0&jk=f7cb547a6e640f0a&k=add&k0=add&kdi0=0&luki=3&n=10&p=baidu&q=06011078_cpr&rb=0&rs=1&seller_id=1&sid=a0f646e7a54cbf7&ssp2=1&stid=0&t=tpclicked3_hc&tu=u1922429&u=http%3A%2F%2Fwww%2Eadmin10000%2Ecom%2Fdocument%2F5360%2Ehtml&urlid=0" id = "2_nwl" > < span style = "color:#0000ff;font-size:14px;width:auto;height:auto;float:none;" > add </ span > </ a > </ span > Class('active'); }); }); // Adding popstate event listener to handle browser back button window.addEventListener("popstate", function(e) { // Get State value using e.state getContent(location.pathname, false); }); function getContent(url, addEntry) { $.get(url) .done(function( < span style = "width: auto; height: auto; float: none;" id = "3_nwp" > < a style = "text-decoration: none;" mpid = "3" target = "_blank" href = "http://cpro.baidu测试数据/cpro/ui/uijs.php?adclass=0&app_id=0&c=news&cf=1001&ch=0&di=128&fv=0&is_app=0&jk=f7cb547a6e640f0a&k=data&k0=data&kdi0=0&luki=6&n=10&p=baidu&q=06011078_cpr&rb=0&rs=1&seller_id=1&sid=a0f646e7a54cbf7&ssp2=1&stid=0&t=tpclicked3_hc&tu=u1922429&u=http%3A%2F%2Fwww%2Eadmin10000%2Ecom%2Fdocument%2F5360%2Ehtml&urlid=0" id = "3_nwl" > < span style = "color:#0000ff;font-size:14px;width:auto;height:auto;float:none;" > data </ span > </ a > </ span > ) { // Updating Content on Page $('#contentHolder').html(data); if( < span style = "width: auto; height: auto; float: none;" id = "4_nwp" > < a style = "text-decoration: none;" mpid = "4" target = "_blank" href = "http://cpro.baidu测试数据/cpro/ui/uijs.php?adclass=0&app_id=0&c=news&cf=1001&ch=0&di=128&fv=0&is_app=0&jk=f7cb547a6e640f0a&k=add&k0=add&kdi0=0&luki=3&n=10&p=baidu&q=06011078_cpr&rb=0&rs=1&seller_id=1&sid=a0f646e7a54cbf7&ssp2=1&stid=0&t=tpclicked3_hc&tu=u1922429&u=http%3A%2F%2Fwww%2Eadmin10000%2Ecom%2Fdocument%2F5360%2Ehtml&urlid=0" id = "4_nwl" > < span style = "color:#0000ff;font-size:14px;width:auto;height:auto;float:none;" > add </ span > </ a > </ span > Entry == true) { // Add History Entry using pushState history.pushState(null, null, url); } }); } </ script >
总结(ps:喜欢这两个字~~~^_^~~~)
HTML 5中的History API 对Web应用有着很大的影响。为了更容易的创建有效率的、对SEO友好的单页面应用,它移除了对散列值的依赖。
总结
以上是 为你收集整理的 深入探究HTML5的History API 全部内容,希望文章能够帮你解决 深入探究HTML5的History API 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。
查看更多关于深入探究HTML5的History API的详细内容...