您好,欢迎访问一九零五行业门户网

jQuery和ajax实现局部刷新

本文主要和大家分享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-*的自定义属性来存储数据,点击的时候修改锚点,因为地址有变,所以刷新的时候仍然会保持当前的页面内容而不是切换到第一个。
相关推荐:
ajax实现带有验证码的局部刷新登录界面
jquery ajax局部刷新实例
jsp+ajax实现的局部刷新较验验证码(onblur事件触发较验)
以上就是jquery和ajax实现局部刷新的详细内容。
其它类似信息

推荐信息