首頁  >  文章  >  web前端  >  jQuery pjax簡單範例匯總

jQuery pjax簡單範例匯總

小云云
小云云原創
2018-01-17 14:04:222165瀏覽

pjax 是一個jQuery插件,它使用 ajax 和 pushState 來實現快速的瀏覽體驗,包括真正的固定鏈接,頁面標題和工作返回按鈕。本文主要和大家分享jQuery pjax簡單範例總結,希望能幫助大家。

ajax缺點是破壞了瀏覽器的前進後退,因為ajax的請求不會留在歷史記錄中。 pjax就不一樣了,pjax被解釋成ajax+pushState的封裝,因為它把ajax的請求寫入歷史記錄,並反映在地址欄,這樣用戶就能愉快地使用前進後退了。 pjax有好幾個實作方法,這裡使用最常用的jQuery函式庫,使用jquery.pjax.js。演示程式碼的伺服器端使用PHP腳本語言。

Pjax用在那裡?就說百度雲盤吧,這個大家一定都用過。百度雲盤PC端,在點擊開啟某個資料夾後會開啟這個資料夾下的文件,其實顯示文件的這個p就用到了pjax技術。網址列變換,內容更換,但卻是一個ajax請求。等到後退的時候,不必重新請求上一層資料夾的內容,因為是存在在歷史記錄中的。而且,開發者還可以選擇時候使用cache和storage快取。

範例一、


<!DOCTYPE html>
<html>
<head>
 <title>pjax</title>
  <meta charset="utf-8">
</head>
<body>
 <h1>My Site</h1>
 <p>
  Go to <a href="res1.php" rel="external nofollow" >第一页</a>.<a href="res2.php" rel="external nofollow" >第二页</a>
 </p>
 <p id="container"></p>  
</body>
<script src="../jquery-2.1.4.min.js"></script>
<script src="../jquery.pjax.js"></script>
<script type="text/javascript">
$(document).pjax(&#39;a&#39;, &#39;#container&#39;)
</script>
</html>

res1.php


<?php 
echo "<p style=&#39;background:red;&#39;>第一页</p>";

res2.php


<?php 
echo "<p style=&#39;background:red;&#39;>第二页</p>";

解釋:

$(document).pjax('a', '#Container') 其中a 是觸發元素, # container 是裝載pjax 回傳內容的容器,下面也是這樣。

範例二、


<!DOCTYPE html>
<html>
<head>
 <title>pjax</title>
  <meta charset="utf-8">
</head>
<body>
 <h1>My Site</h1>
 <p>
  <input type="button" id="clickMe" value="GO">
 </p>
 <p id="container"></p>  
</body>
<script src="../jquery-2.1.4.min.js"></script>
<script src="../jquery.pjax.js"></script>
<script type="text/javascript">
$(function(){
  $(&#39;#clickMe&#39;).click(function(){
    $.pjax({
      url: &#39;./res3.php&#39;,
      container: &#39;#container&#39;
    });
  });
});
</script>
</html>

伺服器端程式碼:

res3.php:


<?php 
echo "<p style=&#39;background:red;&#39;>第三页</p>";

三綜合應用

window.history.pushState(state, title, url);
// https://developer.mozilla.org/zh- CN/docs/Web/API/History/pushState
// @狀態物件:  記錄歷史記錄點的額外物件,可以為空.
// @頁面標題:  目前所有瀏覽器都不支援.
// @可選的URL: 瀏覽器不會檢查URL是否存在,只改變URL.URL必須同域,不能跨域.

PJAX其實就是HTML5 window.history.pushState (state, title, url)這個新的API加上傳統的AJAX技術,一般用來實現無刷新的頁面加載.pushState的作用主要是:改變URL和添加返回歷史.這樣AJAX無刷新加載頁面後,用戶還可以正常進行後退和前進,JS的window.history.back()和window.history.forward()也能正常工作.下面就是一個用pushState + jQuery AJAX實現的無刷新的頁面加載,不支持的瀏覽器則自動退化成開啟原始的連結開啟形式.

index.php:


#
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Index</title>
<script src="jquery.js"></script>
</head>
<body>
<p id="main">
  <a href="data.php" rel="external nofollow" >data.php</a>
  <script>
  $(document).ready(function() {
    $(&#39;#main&#39;).on(&#39;click&#39;,&#39;a&#39;,function(e) {
      if(window.history.pushState) {
        e.preventDefault(); //不跟随原链接跳转
        url = $(this).attr(&#39;href&#39;);
        $.ajax({
          async: true,
          type: &#39;GET&#39;,
          url: &#39;data.php&#39;,
          data: &#39;pjax=1&#39;,
          success: function(data) {
            window.history.pushState(null, null, url); //改变URL和添加返回历史
            document.title = data.title; //设置标题
            $(&#39;#main&#39;).html(data.main); //设置内容
          }
        });
      } else {
        return; //低版本IE8等不支持HTML5 pushState,直接返回进行链接跳转
      }
    });
  });
  </script>
</p>
</body>
</html>

data.php:


<?php
if(isset($_GET[&#39;pjax&#39;])) {
  //PJAX请求返回JSON
  $arr[&#39;title&#39;] = &#39;Data&#39;;
  $arr[&#39;main&#39;] = &#39;<h1>Data Content</h1>&#39;;
  //下面这两句是把PHP数组转成JSON对象返回
  header(&#39;Content-Type: application/json; charset=utf-8&#39;);
  echo json_encode($arr);
} else {
  //常规请求返回HTML
?>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Data</title>
<script src="jquery.js"></script>
</head>
<body>
<p id="main"><h1>Data Content</h1></p>
</body>
</html>
<?php } ?>

注意,JS統計程式碼應該放到main區塊裡面才能正常統計頁面存取數.

範例二:


##

<p class="body"> 
  <?php $action_name = $Think.ACTION_NAME; ?> 
 
  <!-- 头部哟 --> 
  <?php if ($action_name == &#39;news&#39;): ?> 
    <include file="Brand:header_news" /> 
  <?php elseif ($action_name == &#39;forum&#39;): ?> 
    <include file="Brand:header_forum" /> 
  <?php endif; ?> 
 
  <!-- 资讯的二级分类 --> 
  <p class="cb"></p> 
  <p class="brand-news-nav pjax"> 
    <ul class="clearfix"> 
      <li <?php if($_GET[&#39;cat&#39;] == &#39;&#39;) echo &#39;class="selected"&#39;; ?>><a class="first" href="{:U("Brand/$action_name")}">全部</a></li> 
      <volist name="cat_list" id="vo" key="i"> 
        <li <?php if($_GET[&#39;cat&#39;] == $vo[&#39;id&#39;]) echo &#39;class="selected"&#39;; ?>><a href="{:U("Brand/$action_name",array(&#39;cat&#39;=>$vo[&#39;id&#39;]))}">{$vo.name}</a></li> 
      </volist> 
    </ul> 
  </p> 
 
  <script type="text/javascript"> 
    $(function(){ 
      $(document).pjax(&#39;.pjax a&#39;, &#39;#pjax-container&#39;,{ 
        type:&#39;post&#39;, 
        scrollTo:false, 
      }); 
      $(document).on(&#39;pjax:click&#39;, function() { 
        enable_loading = false; 
      }) 
      $(document).on(&#39;pjax:send&#39;, function(){ 
        var str = "<p class=&#39;tc mt-10&#39;>加载中...</p>"; 
        $(&#39;#pjax-container&#39;).html(str); 
      }) 
 
      //最后一个右侧加边框 
      $(".brand-news-nav ul li").last().children(&#39;a&#39;).addClass(&#39;last&#39;); 
      $(".brand-news-nav ul li").click(function(){ 
        $(this).addClass(&#39;selected&#39;).siblings().removeClass(&#39;selected&#39;); 
      }) 
    }) 
  </script> 
 
  <!-- 文章列表页 --> 
  <p class="wrap clearfix"> 
    <p class="brand-news-list fl" id="pjax-container"> 
      <include file="Brand:article_pjax" /> 
    </p> 
    <p class="brand-news-right fr pb-20"> 
      <a href="{$adv3[0][&#39;url&#39;]}"><img class="scrollLoading" data-url="{$adv3[0][&#39;images&#39;]|showImagePath}" src="__PUBLIC__/index/images/loading270x160.gif" width="260" height="150"></a> 
      <p class="title mt-10">法律支持</p> 
      <ul class="bgc-fff"> 
        <volist name="law_list" id="vo"> 
          <a href="{:U(&#39;law&#39;,array(&#39;id&#39;=>$vo[&#39;id&#39;]))}"><li>{$vo.name}</li></a> 
        </volist> 
      </ul> 
      <button class="btn btn-right mt-10 btn-consult">免费咨询</button> 
      <script type="text/javascript"> 
        $(function(){ 
          //最后一个需要添加一个last的样式 
          $(".brand-news-right li:last").addClass(&#39;last&#39;); 
        }) 
      </script> 
    </p> 
  </p> 
</p>

服務端程式碼


if(is_pjax()){ 
  $this->display(&#39;article_pjax&#39;); 
}else{ 
  $this->display(&#39;article&#39;); 
}


//判断是否是pjax请求 
function is_pjax(){ 
  return array_key_exists(&#39;HTTP_X_PJAX&#39;, $_SERVER) && $_SERVER[&#39;HTTP_X_PJAX&#39;]; 
}

其中的主要想法就是當.pjax a進行點擊的時候,將#pjax-container的內容替換為請求後的內容。在後端處理時需要判斷是否為pjax請求,如果需要進行局部渲染,如果不是進行全部渲染。


因為pjax用到了HTML5技術,如果瀏覽器不支援Html5那麼網站會正常進行跳轉式的加載,如果支援那麼只是進行局部渲染(但是瀏覽器網址列中的url會正常跟著a連結進行變動)。


注意上述的js程式碼中在配置pjax時有個參數scrollTo:false,加上此參數表示點擊連接後網頁的scrollBar不會變動,如沒有此參數,每次點擊時瀏覽視窗會自動跳到網頁頂部

小結:Pjax實際上就是從伺服器端返回一段程式碼片段,而不用刷新頁面,並且同時對url 位址進行修改,這樣可以節省資源加載,提升頁面加載速度。

附: pjax的github專案位址

https://github.com/defunkt/jquery-pjax

相關推薦:

# Pjax是什麼

在Laravel 5.1 中使用Pjax

導覽列PJAX刷新問題#

以上是jQuery pjax簡單範例匯總的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn