局部刷新 $.load()

第一种:

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

<!DOCTYPE html>
<html>
  <head>
    <title>ajax局部刷新</title>
  </head>
  <body>

    <header>
      <nav>
        <a href="jq-load.html" class="current">首页</a>
        <a href="jq-load2.html">新闻资讯</a>
        <a href="jq-load3.html">用户中心</a>
      </nav>
    </header>

    <section id="content">
      <div id="container">
          首页的内容
      </div>
    </section>

    <script src="js/jquery-1.11.0.min.js"></script>
    <script src="js/jq-load.js"></script>

  </body>
</html>

 

$('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
});

 

第二种:

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

<!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>

        <div 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>
            <div id="content"></div>
        </div>
        
    </body>
</html>

 

$(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);
});

总结:

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

文章来自于:https://www.cnblogs.com/TigerZhang-home/p/6961301.html   

感谢大神!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值