jQuery+ajax實現局部刷新


在項目中,經常會用到ajax,比如實現局部刷新,比如需要前后端交互等,這里呢分享局部刷新的兩種方法,主要用的是ajax里面的.load(),其他高級方法的使用以后再做詳細筆記。

第一種:

當某幾個頁面都有相同的頭部、導航、底部的時候,點擊導航鏈接可以在幾個頁面中切換,此時想要的效果是點擊鏈接后只切換內容部分,其他不再重新加載。上代碼。

jq-load.html:

 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中創建它們不再贅述。

第二種:

如果網頁的左側有一個列表,點擊列表使右側的內容進行切換,如果右側的內容過多,不適合做選項卡,這時候用.load()局部刷新最好不過了。上代碼。

user.html:

 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-*的自定義屬性來存儲數據,點擊的時候修改錨點,因為地址有變,所以刷新的時候仍然會保持當前的頁面內容而不是切換到第一個。

 

如果有什么問題,還請園子里的朋友多多指教。多謝。

 

 2017-11-15

附上一篇詳細的ajax應用的博文

附上第一個例子的下載鏈接

附上第二個例子的下載鏈接


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM