• HTML 5 History API的”前生今世”


    原文:An Introduction To The HTML5 History API

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

    译者:dwqs

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

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

     

    为什么介绍History API ?

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

            然后,如今对于HTML 5的History API来说,这些都是能够轻易实现的,可是因为单页面应用不是必需使用散列值,它可能须要额外的开发脚本。它也同意我们用一种对SEO友好的方式建立新应用。此外,它能降低带宽,可是该怎么证明呢?

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

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

    注意,您须要运行一些server端编码仅仅提供部分资源,而不是完整的页面内容。

     

    浏览器支持

             在写这篇文章的时候,各主流浏览器对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提供了两个新方法:

                  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.

    比較结果例如以下图:

    push-vs-replace-state

            到此,为了控制浏览器的历史记录,我们忽略了pushState()replaceState()的事件。可是如果浏览器统计了很多的不良记录,用户可能会被重定向到这些页面,也许也不会。在这样的情况下,当用户使用浏览器的前进和后退导航button时就会产生意外的问题。

            虽然当我们使用pushState()replaceState()进行处理时,期待popstate事件被触发。但实际上,情况并非这样。相反,当你浏览会话历史记录时,无论你是点击前进或者后退button,还是使用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

    历史条目在浏览器中被计算,而且能够非常easy的使用浏览器的前进和后退button。View Demo  (ps:你在点击demo1的选项卡时,其记录会被加入到浏览器的历史记录,当点击后退/前进button时,能够回到/跳到你之前点击的选项卡相应的页面)

              Demo 2:HTML 5 History API – replaceState

    历史条目在浏览器中被更新,而且不能使用浏览器的前进和后退button进行浏览。View Demo  (ps:你在点击demo1的选项卡时,其记录会被替换当前浏览器的历史记录,当点击后退/前进button时,不能够回到/跳到你之前点击的选项卡相应的页面,而是返回/跳到你进入demo2的上一个页面)

    总结(ps:喜欢这两个字~~~^_^~~~)

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

    下一篇:你在博客收录集吗?

  • 相关阅读:
    poj1417(带权并查集+背包DP+路径回溯)
    poj1182(带权并查集)
    hdoj3038(带权并查集)
    poj1611(并查集简单应用)
    poj2236(并查集)
    莫队板子,例题
    离散化二维坐标
    P2921 [USACO08DEC]在农场万圣节Trick or Treat on the Farm
    树链剖分板子
    P2486 [SDOI2011]染色 区间合并+树链剖分(加深对线段树的理解)
  • 原文地址:https://www.cnblogs.com/blfshiye/p/4295939.html
Copyright © 2020-2023  润新知