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

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

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

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

第一種:

當(dāng)某幾個(gè)頁(yè)面都有相同的頭部、導(dǎo)航、底部的時(shí)候,點(diǎn)擊導(dǎo)航鏈接可以在幾個(gè)頁(yè)面中切換,此時(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">首頁(yè)</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">
     首頁(yè)的內(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)頁(yè)的左側(cè)有一個(gè)列表,點(diǎn)擊列表使右側(cè)的內(nèi)容進(jìn)行切換,如果右側(cè)的內(nèi)容過(guò)多,不適合做選項(xiàng)卡,這時(shí)候用.load()局部刷新最好不過(guò)了。上代碼。

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的頁(yè)面也是列表相對(duì)應(yīng)的內(nèi)容,此處不再贅述。

總結(jié):

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

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

相關(guān)文章

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

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

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

    基于jQuery解決ios10以上版本縮放問(wèn)題

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

    jQuery動(dòng)畫(huà)效果實(shí)現(xiàn)圖片無(wú)縫連續(xù)滾動(dòng)

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

    jquery制作圖片時(shí)鐘特效

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

    jQuery插件實(shí)現(xiàn)表格隔行換色且感應(yīng)鼠標(biāo)高亮行變色

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

    jQuery使用技巧簡(jiǎn)單匯總

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

    juqery 學(xué)習(xí)之三 選擇器 可見(jiàn)性 元素屬性

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

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

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

    jquery分頁(yè)對(duì)象使用示例

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

    jQuery.each()用法分享

    昨天寫(xiě)了個(gè)小插件,用到這個(gè)方法,不太明白$.each()這個(gè)方法,今天查了下手冊(cè),學(xué)習(xí)一下
    2012-07-07

最新評(píng)論