在项目中,经常会用到ajax,比如实现局部刷新,比如需要前后端交互等,这里呢分享局部刷新的两种方法,主要用的是ajax里面的.load(),其他高级方法的使用以后再做详细笔记。

第一种:

当某几个页面都有相同的头部、导航、底部的时候,点击导航链接可以在几个页面中切换,此时想要的效果是点击链接后只切换内容部分,其他不再重新加载。上代码。

jq-load.html:

  1. 1 <!DOCTYPE html>
  2. 2 <html>
  3. 3 <head>
  4. 4 <title>ajax局部刷新</title>
  5. 5 </head>
  6. 6 <body>
  7. 7
  8. 8 <header>
  9. 9 <nav>
  10. 10 <a href="jq-load.html" class="current">首页</a>
  11. 11 <a href="jq-load2.html">新闻资讯</a>
  12. 12 <a href="jq-load3.html">用户中心</a>
  13. 13 </nav>
  14. 14 </header>
  15. 15
  16. 16 <section id="content">
  17. 17 <div id="container">
  18. 18 首页的内容
  19. 19 </div>
  20. 20 </section>
  21. 21
  22. 22 <script src="js/jquery-1.11.0.min.js"></script>
  23. 23 <script src="js/jq-load.js"></script>
  24. 24
  25. 25 </body>
  26. 26 </html>

注:jq-load2.html、jq-load3.html与jq-load.html代码基本一致,只在#container的div里展示的内容不一样。

jq-load.js:

  1. 1 $(\'nav a\').on(\'click\', function(e) {
  2. 2 e.preventDefault(); // 阻止链接跳转
  3. 3 var url = this.href; // 保存点击的地址
  4. 4
  5. 5 $(\'nav a.current\').removeClass(\'current\');
  6. 6 $(this).addClass(\'current\');
  7. 7
  8. 8 $(\'#container\').remove();
  9. 9 $(\'#content\').load(url + \' #container\').fadeIn(\'slow\'); // 加载新内容,url地址与该地址下的选择器之间要有空格,表示该url下的#container
  10. 10 });

注:此种方法用到了一些html5里面的新标记,在js中创建它们不再赘述。

第二种:

如果网页的左侧有一个列表,点击列表使右侧的内容进行切换,如果右侧的内容过多,不适合做选项卡,这时候用.load()局部刷新最好不过了。上代码。

user.html:

  1. 1 <!DOCTYPE html>
  2. 2 <html lang="en">
  3. 3 <head>
  4. 4 <title>个人中心</title>
  5. 5 <meta charset="utf-8">
  6. 6 <script src="js/jquery-1.11.0.min.js"></script>
  7. 7 <script src="js/user.js"></script>
  8. 8 </head>
  9. 9 <body>
  10. 10
  11. 11 <div class="userWrap">
  12. 17 <ul class="userMenu">
  13. 18 <li class="current" data-id="center">用户中心</li>
  14. 19 <li data-id="account">账户信息</li>
  15. 20 <li data-id="trade">交易记录</li>
  16. 21 <li data-id="info">消息中心</li>
  17. 22 </ul>
  18. 23 <div id="content"></div>
  19. 25 </div>
  20. 26
  21. 27 </body>
  22. 28 </html>

user.js:

  1. $(function(){
  2. $(".userMenu").on("click", "li", function(){
  3. var sId = $(this).data("id"); //获取data-id的值
  4. window.location.hash = sId; //设置锚点
  5. loadInner(sId);
  6. });
  7. function loadInner(sId){
  8. var sId = window.location.hash;
  9. var pathn, i;
  10. switch(sId){
  11. case "#center": pathn = "user_center.html"; i = 0; break;
           case "#account": pathn = "user_account.html"; i = 1; break;
  12. case "#trade": pathn = "user_trade.html"; i = 2; break;
  13. case "#info": pathn = "user_info.html"; i = 3; break;
           default: pathn = "user_center.html"; i = 0; break;
  14. }
  15. $("#content").load(pathn); //加载相对应的内容
  16. $(".userMenu li").eq(i).addClass("current").siblings().removeClass("current"); //当前列表高亮
  17. }
  18. var sId = window.location.hash;
  19. loadInner(sId);
  20. });

user_center.html:

  1. <div>
  2. 用户中心
  3. ……
  4. </div>

注:其他user_xxx.html的页面也是列表相对应的内容,此处不再赘述。

总结:

以上两种方法原理是一样的,通过.load()重新加载页面中的某一部分,需注意,ajax需要在服务器环境下运行。通过对比,可发现第一种比较简单,第二种稍复杂些,不过个人推荐第二种,第一种主要是举个例子,看.load()是怎么来用的,其实它在用户体验方面稍逊一筹,比如点击的时候地址栏里地址不变,使前进、后退失效,这个可以到后面再实现。而第二种的话运用比较灵活,巧妙的借助data-*的自定义属性来存储数据,点击的时候修改锚点,因为地址有变,所以刷新的时候仍然会保持当前的页面内容而不是切换到第一个。

 

如果有什么问题,还请园子里的朋友多多指教。多谢。

 

 2017-11-15

附上一篇详细的ajax应用的博文

附上第一个例子的下载链接

附上第二个例子的下载链接

版权声明:本文为zlts原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/zlts/p/6960074.html