名站网址导航名站网址导航小编为爱好网页hTML5的朋友提供关于网页hTML5的相关知识。
- 本篇文章的具体介绍如下
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 onl oad event, but Firefox and IE do not have this behavior.(在WebKit浏览器中,popstate事件在document的onload事件后触发,Firefox和IE没有这种行为)。
Demo示例
网页hTML:
- <div class="container">
- <div 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>
- </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> method.
- </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; height: auto; float: none;" id="5_nwp"><a style="text-decoration: none;" mpid="5" target="_blank" href="http://cpro.baidu.com/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=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://www.admin10000.com/document/5360.html&urlid=0" id="5_nwl"><span style="color:#0000ff;font-size:14px;width:auto;height:auto;float:none;">printing</span></a></span> and typesetting 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.com/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://www.admin10000.com/document/5360.html&urlid=0" id="1_nwl"><span style="color:#0000ff;font-size:14px;width:auto;height:auto;float:none;">javascript</span></a></span>">
- 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).<span style="width: auto; height: auto; float: none;" id="2_nwp"><a style="text-decoration: none;" mpid="2" target="_blank" href="http://cpro.baidu.com/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://www.admin10000.com/document/5360.html&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.com/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://www.admin10000.com/document/5360.html&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.com/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://www.admin10000.com/document/5360.html&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的相关知识就说到这里希望可以帮助朋友们。,网页hTML5,history网页hTML5教程中Localstorage的使用教程
前几天在老项目中发现有对cookie的操作觉得很奇怪,咨询下来是要缓存一些信息,以避免在URL上面传递具体参数,但没有考虑过cookie会带来什么问题: