真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

jQuery中pjax如何使用

本篇文章給大家分享的是有關(guān)jQuery中pjax如何使用,小編覺得挺實用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

為靈丘等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及靈丘網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都做網(wǎng)站、網(wǎng)站制作、靈丘網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達到每一位用戶的要求,就會得到認可,從而選擇與我們長期合作。這樣,我們也可以走得更遠!

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緩存。

示例一、




 pjax
  


 

My Site

 
  Go to 第一頁.第二頁  
 
   $(document).pjax('a', '#container')

res1.php

第一頁
";

res2.php

第二頁
";

解釋:

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

示例二、




 pjax
  


 

My Site

 
    
    $(function(){   $('#clickMe').click(function(){     $.pjax({       url: './res3.php',       container: '#container'     });   }); });

服務(wù)器端代碼:

res3.php:

第三頁";

三綜合應(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:





Index




  data.php
  


data.php:

Data Content';
  //下面這兩句是把PHP數(shù)組轉(zhuǎn)成JSON對象返回
  header('Content-Type: application/json; charset=utf-8');
  echo json_encode($arr);
} else {
  //常規(guī)請求返回HTML
?>




Data



Data Content

注意,JS統(tǒng)計代碼應(yīng)該放到main塊里面才能正常統(tǒng)計頁面訪問數(shù).

示例二:

 
   
 
   
   
     
   
     
   
 
   
   
   
     
      >全部 
       
        >$vo['id']))}">{$vo.name} 
       
     
   
 
   
    $(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 = "加載中...

";          $('#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');        })      })                                                        法律支持

                              $vo['id']))}">
  • {$vo.name}
  •                           免費咨詢                  $(function(){            //最后一個需要添加一個last的樣式            $(".brand-news-right li:last").addClass('last');          })                   

    服務(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)行業(yè)資訊頻道。


    網(wǎng)站題目:jQuery中pjax如何使用
    網(wǎng)站地址:http://weahome.cn/article/jdgghs.html

    其他資訊

    在線咨詢

    微信咨詢

    電話咨詢

    028-86922220(工作日)

    18980820575(7×24)

    提交需求

    返回頂部