在項目中,常常會用到ajax,好比實現局部刷新,好比須要先後端交互等,這裏呢分享局部刷新的兩種方法,主要用的是ajax裏面的.load(),其餘高級方法的使用之後再作詳細筆記。html
第一種:html5
當某幾個頁面都有相同的頭部、導航、底部的時候,點擊導航連接能夠在幾個頁面中切換,此時想要的效果是點擊連接後只切換內容部分,其餘再也不從新加載。上代碼。jquery
jq-load.html:ajax
1 <!DOCTYPE html> 2 <html> 3 <head> 4 <title>ajax局部刷新</title> 5 </head> 6 <body> 7 8 <header> 9 <nav> 10 <a href="jq-load.html" class="current">首頁</a> 11 <a href="jq-load2.html">新聞資訊</a> 12 <a href="jq-load3.html">用戶中心</a> 13 </nav> 14 </header> 15 16 <section id="content"> 17 <div id="container"> 18 首頁的內容 19 </div> 20 </section> 21 22 <script src="js/jquery-1.11.0.min.js"></script> 23 <script src="js/jq-load.js"></script> 24 25 </body> 26 </html>
注:jq-load2.html、jq-load3.html與jq-load.html代碼基本一致,只在#container的div裏展現的內容不同。後端
jq-load.js:服務器
1 $('nav a').on('click', function(e) { 2 e.preventDefault(); // 阻止連接跳轉 3 var url = this.href; // 保存點擊的地址 4 5 $('nav a.current').removeClass('current'); 6 $(this).addClass('current'); 7 8 $('#container').remove(); 9 $('#content').load(url + ' #container').fadeIn('slow'); // 加載新內容,url地址與該地址下的選擇器之間要有空格,表示該url下的#container 10 });
注:此種方法用到了一些html5裏面的新標記,在js中建立它們再也不贅述。post
第二種:this
若是網頁的左側有一個列表,點擊列表使右側的內容進行切換,若是右側的內容過多,不適合作選項卡,這時候用.load()局部刷新最好不過了。上代碼。url
user.html:spa
1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <title>我的中心</title> 5 <meta charset="utf-8"> 6 <script src="js/jquery-1.11.0.min.js"></script> 7 <script src="js/user.js"></script> 8 </head> 9 <body> 10 11 <div class="userWrap"> 17 <ul class="userMenu"> 18 <li class="current" data-id="center">用戶中心</li> 19 <li data-id="account">帳戶信息</li> 20 <li data-id="trade">交易記錄</li> 21 <li data-id="info">消息中心</li> 22 </ul> 23 <div id="content"></div> 25 </div> 26 27 </body> 28 </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:
<div> 用戶中心 …… </div>
注:其餘user_xxx.html的頁面也是列表相對應的內容,此處再也不贅述。
總結:
以上兩種方法原理是同樣的,經過.load()從新加載頁面中的某一部分,需注意,ajax須要在服務器環境下運行。經過對比,可發現第一種比較簡單,第二種稍複雜些,不過我的推薦第二種,第一種主要是舉個例子,看.load()是怎麼來用的,其實它在用戶體驗方面稍遜一籌,好比點擊的時候地址欄裏地址不變,使前進、後退失效,這個能夠到後面再實現。而第二種的話運用比較靈活,巧妙的藉助data-*的自定義屬性來存儲數據,點擊的時候修改錨點,由於地址有變,因此刷新的時候仍然會保持當前的頁面內容而不是切換到第一個。
若是有什麼問題,還請園子裏的朋友多多指教。多謝。