jQuery+ajax實(shí)現(xiàn)局部刷新的兩種方法
在項(xiàng)目中,經(jīng)常會用到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); //加載相對應(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)境下運(yùn)行。通過對比,可發(fā)現(xiàn)第一種比較簡單,第二種稍復(fù)雜些,不過個(gè)人推薦第二種,第一種主要是舉個(gè)例子,看.load()是怎么來用的,其實(shí)它在用戶體驗(yàn)方面稍遜一籌,比如點(diǎn)擊的時(shí)候地址欄里地址不變,使前進(jìn)、后退失效,這個(gè)可以到后面再實(shí)現(xiàn)。而第二種的話運(yùn)用比較靈活,巧妙的借助data-*的自定義屬性來存儲數(shù)據(jù),點(diǎn)擊的時(shí)候修改錨點(diǎn),因?yàn)榈刂酚凶?,所以刷新的時(shí)候仍然會保持當(dāng)前的頁面內(nèi)容而不是切換到第一個(gè)。
以上所述是小編給大家介紹的jQuery+ajax實(shí)現(xiàn)局部刷新的兩種方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- JQuery的Ajax請求實(shí)現(xiàn)局部刷新的簡單實(shí)例
- ajax局部刷新一個(gè)div下jsp內(nèi)容的方法
- jquery ajax 局部刷新小案例
- ajax局部刷新實(shí)例 (三種方法推薦)
- Ajax實(shí)現(xiàn)帶有驗(yàn)證碼的局部刷新登錄界面
- 純JS實(shí)現(xiàn)AJAX局部刷新功能
- AJAX的原理—如何做到異步和局部刷新【實(shí)現(xiàn)代碼】
- 利用ajax實(shí)現(xiàn)簡單的注冊驗(yàn)證局部刷新實(shí)例
- Ajax局部刷新應(yīng)用案例---簡單登錄
- Ajax實(shí)現(xiàn)局部刷新的方法實(shí)例
相關(guān)文章
jQuery動(dòng)畫效果實(shí)現(xiàn)圖片無縫連續(xù)滾動(dòng)
這篇文章主要為大家介紹了jQuery動(dòng)畫效果實(shí)現(xiàn)圖片無縫連續(xù)滾動(dòng),實(shí)現(xiàn)類似連續(xù)不間斷的滾動(dòng)廣告位,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-01-01
jQuery插件實(shí)現(xiàn)表格隔行換色且感應(yīng)鼠標(biāo)高亮行變色
實(shí)現(xiàn)表格隔行換色,且感應(yīng)鼠標(biāo)行變色的方法有很多,在本文將為大家介紹的是使用jQuery插件來實(shí)現(xiàn),具體如下,感興趣的朋友可以練練手2013-09-09
juqery 學(xué)習(xí)之三 選擇器 可見性 元素屬性
juqery 學(xué)習(xí)之三 選擇器 可見性 元素屬性,需要的朋友可以參考下。2010-11-11

