欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

jQuery+ajax實現(xiàn)局部刷新的兩種方法

 更新時間:2017年06月08日 08:32:53   作者:幽影一殤  
在項目中,經(jīng)常會用到ajax,比如實現(xiàn)局部刷新,比如需要前后端交互等,這里呢分享局部刷新的兩種方法,主要用的是ajax里面的.load()。感興趣的朋友一起看看吧

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

第一種:

當某幾個頁面都有相同的頭部、導航、底部的時候,點擊導航鏈接可以在幾個頁面中切換,此時想要的效果是點擊鏈接后只切換內(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(); // 阻止鏈接跳轉
 var url = this.href; // 保存點擊的地址

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

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

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

第二種:

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

user.html:

<!DOCTYPE html>
<html lang="en">
  <head>
    <title>個人中心</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; //設置錨點
    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); //加載相對應的內(nèi)容
    $(".userMenu li").eq(i).addClass("current").siblings().removeClass("current"); //當前列表高亮
  }
  var sId = window.location.hash;
  loadInner(sId);
});

user_center.html:

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

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

總結:

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

以上所述是小編給大家介紹的jQuery+ajax實現(xiàn)局部刷新的兩種方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關文章

  • 初窺JQuery(二) 事件機制(1)

    初窺JQuery(二) 事件機制(1)

    JQuery的事件處理機制在JQuery框架中起著重要的左右,它就像電視機的開關,我們打開電視機的開關才能看到各個電視臺精彩的節(jié)目,那么我們使用JQuery的事件處理機制就可以創(chuàng)造我們自定義的行為,比如說提交、改變樣式、效果顯示等等,使我們的網(wǎng)頁更加豐富。
    2010-11-11
  • 基于jQuery解決ios10以上版本縮放問題

    基于jQuery解決ios10以上版本縮放問題

    本文通過一段示例代碼給大家介紹了基于jQuery解決ios10以上版本縮放問題,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-11-11
  • jQuery動畫效果實現(xiàn)圖片無縫連續(xù)滾動

    jQuery動畫效果實現(xiàn)圖片無縫連續(xù)滾動

    這篇文章主要為大家介紹了jQuery動畫效果實現(xiàn)圖片無縫連續(xù)滾動,實現(xiàn)類似連續(xù)不間斷的滾動廣告位,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-01-01
  • jquery制作圖片時鐘特效

    jquery制作圖片時鐘特效

    這篇文章主要為大家詳細介紹了jquery制作圖片時鐘特效,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2015-11-11
  • jQuery插件實現(xiàn)表格隔行換色且感應鼠標高亮行變色

    jQuery插件實現(xiàn)表格隔行換色且感應鼠標高亮行變色

    實現(xiàn)表格隔行換色,且感應鼠標行變色的方法有很多,在本文將為大家介紹的是使用jQuery插件來實現(xiàn),具體如下,感興趣的朋友可以練練手
    2013-09-09
  • jQuery使用技巧簡單匯總

    jQuery使用技巧簡單匯總

    本文將詳細介紹下jQuery對象作為數(shù)組處理、創(chuàng)建一個空的jQuery對象、selector屬性、選擇隨機元素,感興趣的朋友可以參考下哈
    2013-04-04
  • juqery 學習之三 選擇器 可見性 元素屬性

    juqery 學習之三 選擇器 可見性 元素屬性

    juqery 學習之三 選擇器 可見性 元素屬性,需要的朋友可以參考下。
    2010-11-11
  • 20款超贊的jQuery插件 Web開發(fā)人員必備

    20款超贊的jQuery插件 Web開發(fā)人員必備

    jQuery的易擴展性吸引了來自全球的開發(fā)者來共同編寫jQuery插件。jQuery插件不僅能夠增強網(wǎng)站的可用性,有效地改善用戶體驗,還可以大大減少開發(fā)時間?,F(xiàn)在的jQuery插件很多,可以根據(jù)您的項目需要來選擇。這里為您介紹20款非常不錯的插件。
    2011-02-02
  • jquery分頁對象使用示例

    jquery分頁對象使用示例

    這篇文章主要介紹了jquery分頁對象使用示例,需要的朋友可以參考下
    2014-04-04
  • jQuery.each()用法分享

    jQuery.each()用法分享

    昨天寫了個小插件,用到這個方法,不太明白$.each()這個方法,今天查了下手冊,學習一下
    2012-07-07

最新評論