您好,欢迎访问一九零五行业门户网

h5中History API 对Web应用的影响

history是有趣的,不是吗?在之前的html版本中,我们对浏览历史记录的操作非常有限。我们可以来回使用可以使用的方法,但这就是一切我们能做的了。
但是,利用html 5的history api,我们可以更好的控制浏览器的历史记录了。例如:我们可以添加一条记录到历史记录的列表中,或者在没有刷新时,可以更新地址栏的url。
为什么介绍history api ?
在这篇文章中,我们将了解html 5中history api的来源。在此之前,我们经常使用散列值来改变页面内容,特别是那些对页面特别重要的内容。因为没有刷新,所以对于单页面应用,改变其url是不可能的。此外,当你改变url的散列值值,它对浏览器的历史记录没有任何影响。
然后,现在对于html 5的history api来说,这些都是可以轻易实现的,但是由于单页面应用没必要使用散列值,它可能需要额外的开发脚本。它也允许我们用一种对seo友好的方式建立新应用。此外,它能减少带宽,但是该怎么证明呢?
在文章中,我将用history api开发一个单页应用来证明上述的问题。
这也意味着我必须先在首页加载必要的资源。现在开始,页面仅仅加载需要的内容。换句话说,应用并不是一开始就加载了全部的内容,在请求第二个应用内容时,才会被加载。
注意,您需要执行一些服务器端编码只提供部分资源,而不是完整的页面内容。
浏览器支持
在写这篇文章的时候,各主流浏览器对history api的支持是非常不错的,可以点击此处查看其支持情况,这个链接会告诉你支持的浏览器,并使用之前,总有良好的实践来检测支持的特定功能。
为了用变成方式确定浏览器是否支持这个api,可以用下面的一行代码检验: 
return !!(window.history && history.pushstate);
此外,我建议参考一下这篇文章:detect support for various html5 features.(ps:后续会翻译)
如果你是用的现代浏览器,可以用下面的代码:
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字符串,可以用在popstate事件中。
2、title:现在大多数浏览器不支持或者忽略这个参数,最好用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 browsers, a popstate event would be triggered after document’s onload event, but firefox and ie do not have this behavior.(在webkit浏览器中,popstate事件在document的onload事件后触发,firefox和ie没有这种行为)。
demo示例
html:
<p class="container"> <p class="row"> <ul class="nav navbar-nav"> <li><a href="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> </p> <p class="row"> <p class="col-md-6"> <p class="well"> click on links above to see history api usage using <code>pushstate</code> method. </p> </p> <p class="row"> <p class="jumbotron" id="contentholder"> <h1>home!</h1> <p>lorem ipsum is simply dummy text of the printing and typesetting industry.</p> </p> </p> </p> </p>
javascript:
<script type="text/javascript"> jquery('document').ready(function(){ jquery('.historyapi').on('click', function(e){ e.preventdefault(); var href = $(this).attr('href'); // getting content getcontent(href, true); jquery('.historyapi').removeclass('active'); $(this).addclass('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( data ) { // updating content on page $('#contentholder').html(data); if(addentry == true) { // add history entry using pushstate history.pushstate(null, null, url); } }); } </script>
demo 1:html 5 history api – pushstate
历史条目在浏览器中被计算,并且可以很容易的使用浏览器的前进和后退按钮。view demo  (ps:你在点击demo1的选项卡时,其记录会被添加到浏览器的历史记录,当点击后退/前进按钮时,可以回到/跳到你之前点击的选项卡对应的页面)
demo 2:html 5 history api – replacestate
历史条目在浏览器中被更新,并且不能使用浏览器的前进和后退按钮进行浏览。view demo  (ps:你在点击demo1的选项卡时,其记录会被替换当前浏览器的历史记录,当点击后退/前进按钮时,不可以回到/跳到你之前点击的选项卡对应的页面,而是返回/跳到你进入demo2的上一个页面)
总结(ps:喜欢这两个字~~~^_^~~~)
html 5中的history api 对web应用有着很大的影响。为了更容易的创建有效率的、对seo友好的单页面应用,它移除了对散列值的依赖。
【相关推荐】
1. 特别推荐:“php程序员工具箱”v0.1版本下载
2. js中的window.history的用法(一)
3. js中的window.history的用法(二)
4. 深入了解h5中history特性--pushstate、replacestate
5. 详细介绍h5中的history.pushstate()使用实例
以上就是h5中history api 对web应用的影响的详细内容。
其它类似信息

推荐信息