jQuery+ajax如何實(shí)現(xiàn)局部刷新

這篇文章主要介紹了jQuery+ajax如何實(shí)現(xiàn)局部刷新,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

師宗ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!

在項(xiàng)目中,經(jīng)常會(huì)用到ajax,比如實(shí)現(xiàn)局部刷新,比如需要前后端交互等,這里呢分享局部刷新的兩種方法,主要用的是ajax里面的.load()。

第一種:

當(dāng)某幾個(gè)頁面都有相同的頭部、導(dǎo)航、底部的時(shí)候,點(diǎn)擊導(dǎo)航鏈接可以在幾個(gè)頁面中切換,此時(shí)想要的效果是點(diǎn)擊鏈接后只切換內(nèi)容部分,其他不再重新加載。上代碼。

jq-load.html:

<!DOCTYPE html>
<html>
 <head>
  <title>ajax局部刷新</title>
 </head>
 <body>
  <header>
   <nav>
    <a href="jq-load.html" rel="external nofollow" class="current">首頁</a>
    <a href="jq-load2.html" rel="external nofollow" >新聞資訊</a>
    <a href="jq-load3.html" rel="external nofollow" >用戶中心</a>
   </nav>
  </header>
  <section id="content">
   <div id="container">
     首頁的內(nèi)容
   </div>
  </section>
  <script src="js/jquery-1.11.0.min.js"></script>
  <script src="js/jq-load.js"></script>
 </body>
</html>

注:jq-load2.html、jq-load3.html與jq-load.html代碼基本一致,只在#container的div里展示的內(nèi)容不一樣。

jq-load.js:

$('nav a').on('click', function(e) {         
 e.preventDefault(); // 阻止鏈接跳轉(zhuǎn)
 var url = this.href; // 保存點(diǎn)擊的地址

 $('nav a.current').removeClass('current');  
 $(this).addClass('current');           

 $('#container').remove();             
 $('#content').load(url + ' #container').fadeIn('slow'); // 加載新內(nèi)容,url地址與該地址下的選擇器之間要有空格,表示該url下的#container
});

注:此種方法用到了一些html5里面的新標(biāo)記,在js中創(chuàng)建它們不再贅述。

第二種:

如果網(wǎng)頁的左側(cè)有一個(gè)列表,點(diǎn)擊列表使右側(cè)的內(nèi)容進(jìn)行切換,如果右側(cè)的內(nèi)容過多,不適合做選項(xiàng)卡,這時(shí)候用.load()局部刷新最好不過了。上代碼。

user.html:

<!DOCTYPE html>
<html lang="en">
  <head>
    <title>個(gè)人中心</title>
    <meta charset="utf-8">
    <script src="js/jquery-1.11.0.min.js"></script>
    <script src="js/user.js"></script>
  </head>
  <body>
    <div class="userWrap">
      <ul class="userMenu">
        <li class="current" data-id="center">用戶中心</li>
        <li data-id="account">賬戶信息</li>
        <li data-id="trade">交易記錄</li>
        <li data-id="info">消息中心</li>
      </ul>
      <div id="content"></div>
    </div>
  </body>
</html>

user.js:

$(function(){
  $(".userMenu").on("click", "li", function(){
    var sId = $(this).data("id"); //獲取data-id的值
    window.location.hash = sId; //設(shè)置錨點(diǎn)
    loadInner(sId);
  });
  function loadInner(sId){
    var sId = window.location.hash;
    var pathn, i;
    switch(sId){
      case "#center": pathn = "user_center.html"; i = 0; break;
       case "#account": pathn = "user_account.html"; i = 1; break;
      case "#trade": pathn = "user_trade.html"; i = 2; break;
      case "#info": pathn = "user_info.html"; i = 3; break;
       default: pathn = "user_center.html"; i = 0; break;
    }
    $("#content").load(pathn); //加載相對(duì)應(yīng)的內(nèi)容
    $(".userMenu li").eq(i).addClass("current").siblings().removeClass("current"); //當(dāng)前列表高亮
  }
  var sId = window.location.hash;
  loadInner(sId);
});

user_center.html:

<div>
  用戶中心
  ……
</div>

注:其他user_xxx.html的頁面也是列表相對(duì)應(yīng)的內(nèi)容,此處不再贅述。

總結(jié):

以上兩種方法原理是一樣的,通過.load()重新加載頁面中的某一部分,需注意,ajax需要在服務(wù)器環(huán)境下運(yùn)行。通過對(duì)比,可發(fā)現(xiàn)第一種比較簡(jiǎn)單,第二種稍復(fù)雜些,不過個(gè)人推薦第二種,第一種主要是舉個(gè)例子,看.load()是怎么來用的,其實(shí)它在用戶體驗(yàn)方面稍遜一籌,比如點(diǎn)擊的時(shí)候地址欄里地址不變,使前進(jìn)、后退失效,這個(gè)可以到后面再實(shí)現(xiàn)。而第二種的話運(yùn)用比較靈活,巧妙的借助data-*的自定義屬性來存儲(chǔ)數(shù)據(jù),點(diǎn)擊的時(shí)候修改錨點(diǎn),因?yàn)榈刂酚凶?,所以刷新的時(shí)候仍然會(huì)保持當(dāng)前的頁面內(nèi)容而不是切換到第一個(gè)。

jquery是什么

jquery是一個(gè)簡(jiǎn)潔而快速的JavaScript庫,它具有獨(dú)特的鏈?zhǔn)秸Z法和短小清晰的多功能接口、高效靈活的css選擇器,并且可對(duì)CSS選擇器進(jìn)行擴(kuò)展、擁有便捷的插件擴(kuò)展機(jī)制和豐富的插件,是繼Prototype之后又一個(gè)優(yōu)秀的JavaScript代碼庫,能夠用于簡(jiǎn)化事件處理、HTML文檔遍歷、Ajax交互和動(dòng)畫,以便快速開發(fā)網(wǎng)站。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“jQuery+ajax如何實(shí)現(xiàn)局部刷新”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

網(wǎng)頁標(biāo)題:jQuery+ajax如何實(shí)現(xiàn)局部刷新
網(wǎng)址分享:http://bm7419.com/article40/ipooeo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營銷型網(wǎng)站建設(shè)、、定制網(wǎng)站、標(biāo)簽優(yōu)化、定制開發(fā)、網(wǎng)站營銷

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化