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('a', '#container') </script> </html>
res1.php
<?php echo "<p style='background:red;'>第一页</p>";
res2.php
<?php echo "<p style='background:red;'>第二页</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(){ $('#clickMe').click(function(){ $.pjax({ url: './res3.php', container: '#container' }); }); }); </script> </html>
伺服器端程式碼:
res3.php:
<?php echo "<p style='background:red;'>第三页</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() { $('#main').on('click','a',function(e) { if(window.history.pushState) { e.preventDefault(); //不跟随原链接跳转 url = $(this).attr('href'); $.ajax({ async: true, type: 'GET', url: 'data.php', data: 'pjax=1', success: function(data) { window.history.pushState(null, null, url); //改变URL和添加返回历史 document.title = data.title; //设置标题 $('#main').html(data.main); //设置内容 } }); } else { return; //低版本IE8等不支持HTML5 pushState,直接返回进行链接跳转 } }); }); </script> </p> </body> </html>
data.php:
<?php if(isset($_GET['pjax'])) { //PJAX请求返回JSON $arr['title'] = 'Data'; $arr['main'] = '<h1>Data Content</h1>'; //下面这两句是把PHP数组转成JSON对象返回 header('Content-Type: application/json; charset=utf-8'); 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 == 'news'): ?> <include file="Brand:header_news" /> <?php elseif ($action_name == 'forum'): ?> <include file="Brand:header_forum" /> <?php endif; ?> <!-- 资讯的二级分类 --> <p class="cb"></p> <p class="brand-news-nav pjax"> <ul class="clearfix"> <li <?php if($_GET['cat'] == '') echo 'class="selected"'; ?>><a class="first" href="{:U("Brand/$action_name")}">全部</a></li> <volist name="cat_list" id="vo" key="i"> <li <?php if($_GET['cat'] == $vo['id']) echo 'class="selected"'; ?>><a href="{:U("Brand/$action_name",array('cat'=>$vo['id']))}">{$vo.name}</a></li> </volist> </ul> </p> <script type="text/javascript"> $(function(){ $(document).pjax('.pjax a', '#pjax-container',{ type:'post', scrollTo:false, }); $(document).on('pjax:click', function() { enable_loading = false; }) $(document).on('pjax:send', function(){ var str = "<p class='tc mt-10'>加载中...</p>"; $('#pjax-container').html(str); }) //最后一个右侧加边框 $(".brand-news-nav ul li").last().children('a').addClass('last'); $(".brand-news-nav ul li").click(function(){ $(this).addClass('selected').siblings().removeClass('selected'); }) }) </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]['url']}"><img class="scrollLoading" data-url="{$adv3[0]['images']|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('law',array('id'=>$vo['id']))}"><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('last'); }) </script> </p> </p> </p>服務端程式碼
if(is_pjax()){ $this->display('article_pjax'); }else{ $this->display('article'); }
//判断是否是pjax请求 function is_pjax(){ return array_key_exists('HTTP_X_PJAX', $_SERVER) && $_SERVER['HTTP_X_PJAX']; }其中的主要想法就是當.pjax a進行點擊的時候,將#pjax-container的內容替換為請求後的內容。在後端處理時需要判斷是否為pjax請求,如果需要進行局部渲染,如果不是進行全部渲染。
https://github.com/defunkt/jquery-pjax
相關推薦:以上是jQuery pjax簡單範例匯總的詳細內容。更多資訊請關注PHP中文網其他相關文章!