您好,登錄后才能下訂單哦!
這篇文章主要介紹了jQuery+ajax如何實現(xiàn)局部刷新,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
在項目中,經(jīng)常會用到ajax,比如實現(xiàn)局部刷新,比如需要前后端交互等,這里呢分享局部刷新的兩種方法,主要用的是ajax里面的.load()。
第一種:
當(dāng)某幾個頁面都有相同的頭部、導(dǎo)航、底部的時候,點擊導(dǎo)航鏈接可以在幾個頁面中切換,此時想要的效果是點擊鏈接后只切換內(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; // 保存點擊的地址 $('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è)有一個列表,點擊列表使右側(cè)的內(nèi)容進(jìn)行切換,如果右側(cè)的內(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; //設(shè)置錨點 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); //加載相對應(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īng)的內(nèi)容,此處不再贅述。
總結(jié):
以上兩種方法原理是一樣的,通過.load()重新加載頁面中的某一部分,需注意,ajax需要在服務(wù)器環(huán)境下運行。通過對比,可發(fā)現(xiàn)第一種比較簡單,第二種稍復(fù)雜些,不過個人推薦第二種,第一種主要是舉個例子,看.load()是怎么來用的,其實它在用戶體驗方面稍遜一籌,比如點擊的時候地址欄里地址不變,使前進(jìn)、后退失效,這個可以到后面再實現(xiàn)。而第二種的話運用比較靈活,巧妙的借助data-*的自定義屬性來存儲數(shù)據(jù),點擊的時候修改錨點,因為地址有變,所以刷新的時候仍然會保持當(dāng)前的頁面內(nèi)容而不是切換到第一個。
jquery是一個簡潔而快速的JavaScript庫,它具有獨特的鏈?zhǔn)秸Z法和短小清晰的多功能接口、高效靈活的css選擇器,并且可對CSS選擇器進(jìn)行擴(kuò)展、擁有便捷的插件擴(kuò)展機制和豐富的插件,是繼Prototype之后又一個優(yōu)秀的JavaScript代碼庫,能夠用于簡化事件處理、HTML文檔遍歷、Ajax交互和動畫,以便快速開發(fā)網(wǎng)站。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“jQuery+ajax如何實現(xiàn)局部刷新”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。