本文主要和大家分享jQuery和ajax實現局部刷新的兩種不同方法,在專案中,常會用到ajax,例如實現局部刷新,例如需要前後端互動等,這裡呢分享局部刷新的兩種法,主要用的是ajax裡面的.load()。有興趣的朋友一起看看吧。
第一種:
當某幾個頁面都有相同的頭部、導航、底部的時候,點擊導航連結可以在幾個頁面中切換,此時想要的效果是點擊連結後只切換內容部分,其他不再重新載入。上代碼。
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"> <p id="container"> 首页的内容 </p> </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的p裡展示的內容不一樣。
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'); // 加载新内容,url地址与该地址下的选择器之间要有空格,表示该url下的#container });
註:此種方法用到了一些html5裡面的新標記,在js中建立它們不再贅述。
第二種:
如果網頁的左側有一個列表,點擊列表使右側的內容進行切換,如果右側的內容過多,不適合做選項卡,這時候用.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> <p 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> <p id="content"></p> </p> </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); //加载相对应的内容 $(".userMenu li").eq(i).addClass("current").siblings().removeClass("current"); //当前列表高亮 } var sId = window.location.hash; loadInner(sId); });
user_center.html:
<p> 用户中心 …… </p>
註:其他user_xxx.html的頁面也是清單相對應的內容,此處不再贅述。
總結:
以上兩種方法原理是一樣的,透過.load()重新載入頁面中的某一部分,需注意,ajax需要在伺服器環境下運作。透過對比,可發現第一種比較簡單,第二種稍複雜些,不過個人推薦第二種,第一種主要是舉個例子,看.load()是怎麼來用的,其實它在用戶體驗方面稍遜一籌,例如點擊的時候網址列裡地址不變,使前進、後退失效,這個可以到後面再實現。而第二種的話運用比較靈活,巧妙的借助data-*的自定義屬性來存儲數據,點擊的時候修改錨點,因為地址有變,所以刷新的時候仍然會保持當前的頁面內容而不是切換到第一個。
相關推薦:
jsp+ajax實作的局部刷新較驗驗證碼(onblur事件觸發較驗)
以上是jQuery和ajax實現局部刷新的詳細內容。更多資訊請關注PHP中文網其他相關文章!