HTML 5 History API

原文:An Introduction To The HTML5 History APIjavascript

译文:关于HTML 5 History API 的介绍html

译者:dwqsjava

History是有趣的,不是吗?在以前的HTML版本中,咱们对浏览历史记录的操做很是有限。咱们能够来回使用可使用的方法,但这就是一切咱们能作的了。api

可是,利用HTML 5的History API,咱们能够更好的控制浏览器的历史记录了。例如:咱们能够添加一条记录到历史记录的列表中,或者在没有刷新时,能够更新地址栏的URL。浏览器

为何介绍History API ?

在这篇文章中,咱们将了解HTML 5中History API的来源。在此以前,咱们常用散列值来改变页面内容,特别是那些对页面特别重要的内容。由于没有刷新,因此对于单页面应用,改变其URL是不可能的。此外,当你改变URL的散列值值,它对浏览器的历史记录没有任何影响。服务器

而后,如今对于HTML 5的History API来讲,这些都是能够轻易实现的,可是因为单页面应用不必使用散列值,它可能须要额外的开发脚本。它也容许咱们用一种对SEO友好的方式创建新应用。此外,它能减小带宽,可是该怎么证实呢?this

在文章中,我将用History API开发一个单页应用来证实上述的问题。编码

这也意味着我必须先在首页加载必要的资源。如今开始,页面仅仅加载须要的内容。换句话说,应用并非一开始就加载了所有的内容,在请求第二个应用内容时,才会被加载。url

注意,您须要执行一些服务器端编码只提供部分资源,而不是完整的页面内容。spa

浏览器支持

在写这篇文章的时候,各主流浏览器对History API的支持是很是不错的,能够点击此处查看其支持状况,这个连接会告诉你支持的浏览器,并使用以前,总有良好的实践来检测支持的特定功能。

为了用变成方式肯定浏览器是否支持这个API,能够用下面的一行代码检验:

return !!(window.history && history.pushState);

此外,我建议参考一下这篇文章:Detect Support for Various HTML5 Features.(译文:http://www.ido321.com/1116.html)

若是你是用的现代浏览器,能够用下面的代码:

if (Modernizr.history) {
    // History API Supported
}

若是你的浏览器不支持History API,可使用history.js代替。

使用History

HTML 5提供了两个新方法:

一、history.pushState(); 二、history.replaceState();

两种方法都容许咱们添加和更新历史记录,它们的工做原理相同而且能够添加数量相同的参数。除了方法以外,还有popstate事件。在后文中将介绍怎么使用和何时使用popstate事件。

pushState()和replaceState()参数同样,参数说明以下:

一、state:存储JSON字符串,能够用在popstate事件中。

二、title:如今大多数浏览器不支持或者忽略这个参数,最好用null代替

三、url:任意有效的URL,用于更新浏览器的地址栏,并不在意URL是否已经存在地址列表中。更重要的是,它不会从新加载页面。

两个方法的主要区别就是:pushState()是在history栈中添加一个新的条目,replaceState()是替换当前的记录值。若是你还对这个有迷惑,就用一些示例来证实这个区别。

假设咱们有两个栈块,一个标记为1,另外一个标记为2,你有第三个栈块,标记为3。当执行pushState()时,栈块3将被添加到已经存在的栈中,所以,栈就有3个块栈了。

一样的假设情景下,当执行replaceState()时,将在块2的堆栈和放置块3。因此history的记录条数不变,也就是说,pushState()会让history的数量加1.
比较结果以下图:
push-vs-replace-state_thumb.jpg

到此,为了控制浏览器的历史记录,咱们忽略了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:

<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 printing and typesetting industry.</p>
            </div>
        </div>
    </div>
</div>

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的上一个页面)

总结

HTML 5中的History API 对Web应用有着很大的影响。为了更容易的建立有效率的、对SEO友好的单页面应用,它移除了对散列值的依赖。

原文首发:http://www.ido321.com/1069.html

相关文章
相关标签/搜索