本篇文章給大家分享的是有關(guān)jQuery中pjax如何使用,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比社旗網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式社旗網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋社旗地區(qū)。費用合理售后完善,十年實體公司更值得信賴。pjax 是一個jQuery插件,它使用 ajax 和 pushState 來實現(xiàn)快速的瀏覽體驗,包括真正的固定鏈接,頁面標(biāo)題和工作返回按鈕。
ajax缺點是破壞了瀏覽器的前進后退,因為ajax的請求不會留在歷史記錄中。pjax就不一樣了,pjax被解釋成ajax+pushState的封裝,因為它把ajax的請求寫入歷史記錄,并反映在地址欄,這樣用戶就能愉快地使用前進后退了。pjax有好幾個實現(xiàn)方法,這里使用最常用的jQuery庫,使用jquery.pjax.js。演示代碼的服務(wù)器端使用PHP腳本語言。
Pjax用在那兒?就說百度云盤吧,這個大家肯定都用過。百度云盤PC端,在點擊打開某個文件夾后會打開這個文件夾下的文件,其實顯示文件的這個div就用到了pjax技術(shù)。地址欄變換,內(nèi)容更換,但是卻是一個ajax請求。等到后退的時候,不必重新請求上一層文件夾的內(nèi)容,因為是存在在歷史記錄中的。而且,開發(fā)者還可以選擇時候使用cache和storage緩存。
示例一、
<!DOCTYPE html> <html> <head> <title>pjax</title> <meta charset="utf-8"> </head> <body> <h2>My Site</h2> <div> Go to <a href="res1.php" rel="external nofollow" >第一頁</a>.<a href="res2.php" rel="external nofollow" >第二頁</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 是觸發(fā)元素, #container 是裝載 pjax 返回內(nèi)容的容器,下面也是這樣。
示例二、
<!DOCTYPE html> <html> <head> <title>pjax</title> <meta charset="utf-8"> </head> <body> <h2>My Site</h2> <div> <input type="button" id="clickMe" 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(){ $('#clickMe').click(function(){ $.pjax({ url: './res3.php', container: '#container' }); }); }); </script> </html>
服務(wù)器端代碼:
res3.php:
<?php echo "<div style='background:red;'>第三頁</div>";
三綜合應(yīng)用
window.history.pushState(state, title, url);
// https://developer.mozilla.org/zh-CN/docs/Web/API/History/pushState
// @狀態(tài)對象: 記錄歷史記錄點的額外對象,可以為空.
// @頁面標(biāo)題: 目前所有瀏覽器都不支持.
// @可選的URL: 瀏覽器不會檢查URL是否存在,只改變URL.URL必須同域,不能跨域.
PJAX其實就是HTML5 window.history.pushState(state, title, url)這個新的API加上傳統(tǒng)的AJAX技術(shù),一般用來實現(xiàn)無刷新的頁面加載.pushState的作用主要是:改變URL和添加返回歷史.這樣AJAX無刷新加載頁面后,用戶還可以正常進行后退和前進,JS的window.history.back()和window.history.forward()也能正常工作.下面就是一個用pushState + jQuery AJAX實現(xiàn)的無刷新的頁面加載,不支持的瀏覽器則自動退化成打開原始的鏈接打開形式.
index.php:
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Index</title> <script src="jquery.js"></script> </head> <body> <div 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(); //不跟隨原鏈接跳轉(zhuǎn) 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; //設(shè)置標(biāo)題 $('#main').html(data.main); //設(shè)置內(nèi)容 } }); } else { return; //低版本IE8等不支持HTML5 pushState,直接返回進行鏈接跳轉(zhuǎn) } }); }); </script> </div> </body> </html>
data.php:
<?php if(isset($_GET['pjax'])) { //PJAX請求返回JSON $arr['title'] = 'Data'; $arr['main'] = '<h2>Data Content</h2>'; //下面這兩句是把PHP數(shù)組轉(zhuǎn)成JSON對象返回 header('Content-Type: application/json; charset=utf-8'); echo json_encode($arr); } else { //常規(guī)請求返回HTML ?> <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>Data</title> <script src="jquery.js"></script> </head> <body> <div id="main"><h2>Data Content</h2></div> </body> </html> <?php } ?>
注意,JS統(tǒng)計代碼應(yīng)該放到main塊里面才能正常統(tǒng)計頁面訪問數(shù).
示例二:
<div 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; ?> <!-- 資訊的二級分類 --> <div class="cb"></div> <div 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> </div> <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); }) //最后一個右側(cè)加邊框 $(".brand-news-nav ul li").last().children('a').addClass('last'); $(".brand-news-nav ul li").click(function(){ $(this).addClass('selected').siblings().removeClass('selected'); }) }) </script> <!-- 文章列表頁 --> <div class="wrap clearfix"> <div class="brand-news-list fl" id="pjax-container"> <include file="Brand:article_pjax" /> </div> <div 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> </div> </div> </div>
服務(wù)端代碼
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']; }
其中的主要思想就是當(dāng).pjax a進行點擊的時候,將#pjax-container的內(nèi)容替換為請求后的內(nèi)容。在后端處理時需要判斷是否是pjax請求,如果是需要進行局部渲染,如果不是進行全部渲染。
因為pjax用到了HTML5技術(shù),如果瀏覽器不支持Html5那么網(wǎng)站會正常進行跳轉(zhuǎn)式的加載,如果支持那么只是進行局部渲染(但是瀏覽器地址欄中的url會正常跟著a鏈接進行變動)。
注意上述的js代碼中在配置pjax時有個參數(shù)scrollTo:false,加上此參數(shù)表示點擊連接后網(wǎng)頁的scrollBar不會變動,如沒有此參數(shù),每次點擊時瀏覽視窗會自動跳轉(zhuǎn)到網(wǎng)頁頂部
小結(jié):Pjax實際就是從服務(wù)器端返回一段代碼片段,而不用刷新頁面,并且同時對 url 地址進行修改,這樣可以節(jié)省資源加載,提升頁面加載速度。
以上就是jQuery中pjax如何使用,小編相信有部分知識點可能是我們?nèi)粘9ぷ鲿姷交蛴玫降摹OM隳芡ㄟ^這篇文章學(xué)到更多知識。更多詳情敬請關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站muchs.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
網(wǎng)站標(biāo)題:jQuery中pjax如何使用-創(chuàng)新互聯(lián)
鏈接URL:http://muchs.cn/article14/coside.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版、營銷型網(wǎng)站建設(shè)、域名注冊、企業(yè)網(wǎng)站制作、Google、移動網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)