<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                # [jQuery pjax 簡單入門](https://www.cnblogs.com/kiscall/p/4940101.html) [https://github.com/defunkt/jquery-pjax](https://github.com/defunkt/jquery-pjax)! 以前我們點擊a鏈接的時候總是會刷新整個頁面并跳轉到新頁面,中間可以很明顯的看到短暫的白屏。pjax就很好的解決了這問題。 pjax的原理很簡單,就是發送一個ajax請求,獲取html代碼,再把相關代碼應用到指定容器中,就完成了pjax。pjax除了解決跳轉白屏以外,還能替代iframe,讓前端不得不使用iframe的場景大大減少。 ``` <a class="leftPaneItem" onclick="writeMail()">寫郵件</a> <div id="control"></div> ``` 如果想快速將頁面內所有a標簽替換成pjax的跳轉方式可以寫成這樣: ``` $(document).pjax('a', '#container') ```   Pjax是ajax的升級版,怎么理解呢,當初學習ajax的時候講了ajax的優缺點,其中一個缺點是破壞了瀏覽器的前進后退,因為ajax的請求不會留在歷史記錄中。pjax就不一樣了,pjax被解釋成ajax+pushState的封裝,因為它把ajax的請求寫入歷史記錄,并反映在地址欄,這樣用戶就能愉快地使用前進后退了。pjax有好幾個實現方法,這里使用最常用的Jquery庫,使用jquery.pjax.js。演示代碼的服務器端使用PHP腳本語言。   Pjax用在那兒?就說百度云盤吧,這個大家肯定都用過。百度云盤PC端,在點擊打開某個文件夾后會打開這個文件夾下的文件,其實顯示文件的這個div就用到了pjax技術。地址欄變換,內容更換,但是卻是一個ajax請求。等到后退的時候,不必重新請求上一層文件夾的內容,因為是存在在歷史記錄中的。而且,開發者還可以選擇時候使用cache和storage緩存。 **用法** ~~~ <script type="text/javascript"> $(function () { // 跳轉頁 $(document).on('pjax:complete', function (event, xhr, textStatus, options) { var url = xhr.getResponseHeader('X-PJAX-URL'); if (url) { $.pjax({url: url, container: '.content-wrapper'}) } }); // a 鏈接 $(document).pjax('a[target!=_blank]', '.content-wrapper'); // form 表單 $(document).on('submit', 'form[data-pjax]', function (event) { $.pjax.submit(event, '.content-wrapper'); }); // 阻止超時導致的鏈接跳轉(ajax默認超時時間650毫秒,超時后強制刷新整個頁面) $(document).on('pjax:timeout', function (event) { event.preventDefault() }); // 重新加載 //$.pjax.reload('.content-wrapper'); }) ~~~ DEMO1: 客戶端: ~~~ <!DOCTYPE html> <html> <head> <title>pjax</title> <meta charset="utf-8"> </head> <body> <h1>My Site</h1> <div> Go to <a href="res1.php">第一頁</a>.<a href="res2.php">第二頁</a> </div> <div id="container"></div> </body> <script src="../jquery-2.1.4.min.js"></script> <script src="../jquery.pjax.js"></script> <script type="text/javascript"> $(document).pjax('a', '#container') </script> </html> ~~~ 服務器端: res1.php ~~~ <?php echo "<div style='background:red;'>第一頁</div>"; ~~~ res2.php ~~~ <?php echo "<div style='background:red;'>第二頁</div>"; ~~~ 解釋:$(document).pjax('a', '#container')其中a是觸發元素,#container是裝載pjax返回內容的容器,下面也是這樣。 DEMO2: 客戶端: ~~~ <!DOCTYPE html> <html> <head> <title>pjax</title> <meta charset="utf-8"> </head> <body> <h1>My Site</h1> <div> <input type="button" id="th" value="GO"> </div> <div id="container"></div> </body> <script src="../jquery-2.1.4.min.js"></script> <script src="../jquery.pjax.js"></script> <script type="text/javascript"> $(function(){ $('#th').click(function(){ $.pjax({ url: './res3.php', container: '#container' }); }); }); </script> </html> ~~~ 服務器端代碼: res3.php: ~~~ <?php echo "<div style='background:red;'>第三頁</div>"; ~~~
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看