>  기사  >  웹 프론트엔드  >  jQuery+ 및 ajax를 사용하여 부분 새로 고침 기능을 구현하는 방법

jQuery+ 및 ajax를 사용하여 부분 새로 고침 기능을 구현하는 방법

php中世界最好的语言
php中世界最好的语言원래의
2018-04-25 15:07:011592검색

이번에는 jQuery+와 ajax로 부분 새로 고침 기능을 구현하는 방법을 보여드리겠습니다. jQuery+와 ajax에서 부분 새로 고침 기능을 구현하는 데 있어 주의 사항은 무엇입니까? 다음은 실제 사례입니다.

특정 페이지에 동일한 헤더, navigation 및 하단이 있는 경우 탐색 링크를 클릭하여 여러 페이지 간에 전환할 수 있습니다. 이때 원하는 효과는 링크를 클릭한 후에 내용 부분만 전환하는 것입니다. .그런 다음 다시 로드하세요. 코드를 올려보세요.

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-*의 사용자 정의 속성을 교묘하게 사용합니다. 클릭하면 주소가 변경되므로 새로 고칠 때 현재 페이지 내용이 계속 유지됩니다. . 첫 번째 항목으로 전환하세요.

이 기사의 사례를 읽은 후 방법을 마스터했다고 생각합니다. 더 흥미로운 정보를 보려면 PHP 중국어 웹사이트의 다른 관련 기사를 주목하세요!

추천 자료:

Ajax 사용자 인증 및 등록에 대한 자세한 설명

Ajax 로딩 시간 초과 프롬프트 구현 방법

Ajax 요청 중 진행 상황 표시

위 내용은 jQuery+ 및 ajax를 사용하여 부분 새로 고침 기능을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.