>백엔드 개발 >PHP 튜토리얼 >부트스트랩은 페이지 넘김 효과를 구현합니다.

부트스트랩은 페이지 넘김 효과를 구현합니다.

小云云
小云云원래의
2017-12-07 15:56:432743검색

Twitter의 Bootstrap은 매우 인기 있는 프런트 엔드 프레임워크입니다. Bootstrap은 HTML, CSS 및 JavaScript를 기반으로 하며 간단하고 유연하여 웹 개발을 더 빠르게 만듭니다. 이 기사에서는 페이지 넘김 효과를 달성하기 위한 부트스트랩을 주로 소개하며, 관심 있는 친구들은 이를 참고할 수 있습니다.

장점:

부분 새로 고침 지원
목록인 한 이 구성 요소는 로드될 수 있습니다.
동적 데이터 바인딩을 지원합니다.
물론 매우 간단하고 실용적입니다.

Rendering

마지막 페이지:

부트스트랩은 페이지 넘김 효과를 구현합니다.

첫 페이지:

Implementation

①, 페이지 넘김 컴포넌트 레이아웃


<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ include file="/components/common/taglib.jsp"%>


<c:if test="${urlParas == null}">
 <c:set var="urlParas" value="" />
</c:if>
<c:if test="${(totalPage > 0) && (currentPage <= totalPage)}">
 <c:set var="startPage" value="${currentPage - 4}" />
 <c:if test="${startPage < 1}">
 <c:set var="startPage" value="1" />
 </c:if>
 <c:set var="endPage" value="${currentPage + 4}" />
 <c:if test="${endPage > totalPage}">
 <c:set var="endPage" value="totalPage" />
 </c:if>

 <nav>
 <ul class="pager">
  <c:if test="${currentPage <= 8}">
  <c:set var="startPage" value="1" />
  </c:if>

  <c:if test="${(totalPage - currentPage) < 8}">
  <c:set var="endPage" value="${totalPage}" />
  </c:if>

  <c:choose>
  <c:when test="${currentPage == 1}">
   <li class="previous disabled"><a>
    <span aria-hidden="true">←</span>
    前一页
   </a></li>
  </c:when>
  <c:otherwise>
   <li class="previous"><a href="javascript:;" pageNum="${currentPage - 1}" rel="${rel}" urlParas="${urlParas}">
    <span aria-hidden="true">←</span>
    前一页
   </a></li>
  </c:otherwise>
  </c:choose>

  <c:choose>
  <c:when test="${currentPage == totalPage}">
   <li class="next disabled"><a>
    后一页
    <span aria-hidden="true">→</span>
   </a></li>
  </c:when>
  <c:otherwise>
   <li class="next"><a href="javascript:;" pageNum="${currentPage + 1}" rel="${rel}" urlParas="${urlParas}">
    后一页
    <span aria-hidden="true">→</span>
   </a></li>
  </c:otherwise>
  </c:choose>

 </ul>
 </nav>
</c:if>


  • pageNum : 어느 페이지

  • rel: 새로 고칠 p의 ID

  • urlParas: 기타 매개변수

②, 페이지 넘기기 구성요소 호출


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@ include file="/components/common/taglib.jsp"%>

<c:set var="currentPage" value="${dealPage.pageNumber}" />
<c:set var="totalPage" value="${dealPage.totalPage}" />
<c:set var="rel" value="deal_items" />
<c:set var="urlParas" value="" />

<%@ include file="/components/common/paginate.jsp"%>


  • currentPage: 페이지 수

  • totalPage: 총 페이지 수

  • rel: 부분 새로 고침 ID p

  • urlParas: 기타 매개변수, 없음

3, 페이지 넘김 이벤트


$(function() {
// 翻页组件
 $("ul[class=pager] li:not(.disabled) > a", $p).each(function() {
 $(this).click(function(event) {
  var $this = $(this);
  YUNM.debug($this.attr("pageNum") + "、" + $this.attr("rel") + "、" + $this.attr("urlParas"));

  var pageNum = $this.attr("pageNum");
  // 准备翻页事件
  if (pageNum && pageNum.isPositiveInteger()) {
  yunmPageBreak({
   rel : $this.attr("rel"),
   data : {
   pageNum : pageNum,
   urlParas : $this.attr("urlParas")
   }
  });
  }

  event.preventDefault();
  return false;
 });
 });
});


  • 페이지가 로드된 후 페이지 넘기기 태그를 가져와서 페이지 넘기기 기능을 로드하세요.

  • pageNum을 설정해야 합니다.

  • 부분 새로고침을 받으려면 이 부분을 앞으로 개선해야 할 것 같습니다.

  • 추가 매개변수 urlParas를 전달합니다.

  • 마지막으로 기존 이벤트에서 a 태그를 방지합니다.


/**
 * 翻页
 * 
 * @param options
 */
function yunmPageBreak(options) {
 var op = $.extend({
 rel : "",
 data : {
  pageNum : "",
  numPerPage : "",
  orderField : "",
  orderDirection : "",
  urlParas : ""
 },
 callback : null
 }, options);

 var $panel = $("#" + op.rel);
 if (op.rel) {
 var dataId = $panel.attr("data");

 var url = $panel.attr("url");

 // 设置p上的其他参数
 if (dataId) {
  if (dataId.indexOf(",") != -1) {
  $.each(dataId.split(","), function(index, id) {
   if ($("#" + id) && $("#" + id).val()) {

   url = addMoreParamForUrl(url, id, $("#" + id).val());
   }
  });
  } else {
  if ($("#" + dataId) && $("#" + dataId).val()) {
   url = addMoreParamForUrl(url, dataId, $("#" + dataId).val());
  }
  }
 }

 // 局部刷新
 $panel.ajaxUrl({
  type : "POST",
  url : url,
  data : op.data,
  callback : function(response) {
  if ($.isFunction(op.callback))
   op.callback(response);
  }
 });
 }
}


  • 이 코드 문자열도 이해하기 쉽습니다. ajaxUrl 메소드에 대해서는 내 Ajax 부분 새로 고침에 대한 이야기를 참조하세요. 부분 새로 고침은 여전히 ​​매우 실용적이라고 생각합니다.

  • 이 시점에서 프런트 데스크의 콘텐츠는 괜찮습니다. 다음에는 무엇이 필요합니까? 당연히 jfinal 측의 데이터 수집입니다.
  • 4, 페이지네이션 데이터 획득


  • public Page<Deals> paginateCreateDealsByUid(int pageNumber, int pageSize, Long uid) {
    
     Page<Deals> deals = paginate(pageNumber, pageSize, "select y.*",
      "from ym_dels y where y.uid = ? order by y.opertime desc", uid);
    
     return deals;
    }

jfinal은 자연스럽게 좋은 페이지 넘김 기능인 페이지네이션 방식을 제공합니다.


해당 데이터만 반환하면 됩니다.

  • 관련 권장 사항:

  • 부트스트랩 테이블 서버 측 페이징 처리 처리 방법

PHP+SQLServer의 페이지 넘김 효과 찾기, 처리 방법

HTML5 페이지 만들기 쉬움 회전 효과 텍스트 효과

위 내용은 부트스트랩은 페이지 넘김 효과를 구현합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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