国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

jQuery+pjax簡單示例匯總

2019-11-19 16:46:38
字體:
供稿:網(wǎng)友

pjax 是一個jQuery插件,它使用 ajax 和 pushState 來實現(xiàn)快速的瀏覽體驗,包括真正的固定鏈接,頁面標題和工作返回按鈕。

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> <h1>My Site</h1> <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> <h1>My Site</h1> <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)對象:  記錄歷史記錄點的額外對象,可以為空.
// @頁面標題:  目前所有瀏覽器都不支持.
// @可選的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è)置標題            $('#main').html(data.main); //設(shè)置內(nèi)容          }        });      } else {        return; //低版本IE8等不支持HTML5 pushState,直接返回進行鏈接跳轉(zhuǎn)      }    });  });  </script></div></body></html>

data.php:

<?phpif(isset($_GET['pjax'])) {  //PJAX請求返回JSON  $arr['title'] = 'Data';  $arr['main'] = '<h1>Data Content</h1>';  //下面這兩句是把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"><h1>Data Content</h1></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']; } 

其中的主要思想就是當.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é)省資源加載,提升頁面加載速度。

附: pjax的github項目地址 https://github.com/defunkt/jquery-pjax

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 分宜县| 巫山县| 德格县| 和龙市| 凌源市| 乌拉特中旗| 安龙县| 保康县| 肃南| 黄浦区| 涪陵区| 嵩明县| 民勤县| 平阳县| 泰宁县| 英超| 霍城县| 和硕县| 英山县| 闸北区| 益阳市| 浑源县| 莱西市| 阿拉善盟| 天祝| 阜新市| 梁平县| 平度市| 平阳县| 玉龙| 卢氏县| 桂平市| 京山县| 应用必备| 屯留县| 睢宁县| 连江县| 威远县| 乌什县| 抚松县| 天台县|