Vue 문서의 페이징 바 구성 요소 구현 프로세스에 대한 자세한 설명

PHPz
풀어 주다: 2023-06-20 09:15:27
원래의
1488명이 탐색했습니다.

Vue는 널리 사용되는 JavaScript 프레임워크로서 개발 중에 페이징 기능을 사용해야 하는 경우가 많습니다. Vue 문서는 개발자에게 페이징을 구현하는 편리하고 빠른 방법을 제공하는 페이징 막대 구성 요소를 제공합니다. 이 문서에서는 페이징 바 구성 요소의 구현 프로세스를 자세히 소개합니다.

우선, Vue의 공식 문서에서 Pagination 구성 요소의 구체적인 구현을 찾을 수 있습니다. 구성 요소에서 먼저 Vue 구성 요소와 CSS 스타일을 소개합니다.

<template>
  <nav>
    <ul class="pagination">
      <li v-if="current_page > 1">
        <a href="" aria-label="Previous"
           @click.prevent="changePage(current_page - 1)">
          <span aria-hidden="true">&laquo;</span>
        </a>
      </li>
      <li v-for="page in pages"
          v-bind:class="[ page == current_page ? 'active' : '' ]">
        <a href=""
           @click.prevent="changePage(page)">@{{ page }}</a>
      </li>
      <li v-if="current_page < last_page">
        <a href="" aria-label="Next"
           @click.prevent="changePage(current_page + 1)">
          <span aria-hidden="true">&raquo;</span>
        </a>
      </li>
    </ul>
  </nav>
</template>

<style>
  .pagination li {
    cursor: pointer;
  }
  .pagination li.active span {
    background-color: #3490dc;
    color: #fff;
    border-color: #3490dc;
  }
</style>
로그인 후 복사

이 템플릿에서 다음 핵심 사항을 볼 수 있습니다.

  • v-ifv-for </ code>지침: 이전 페이지와 다음 페이지 표시 여부를 제어하려면 <code>v-if를 사용하고, 페이징 페이지 번호를 순회하려면 v-for를 사용하세요.
  • v-ifv-for指令:通过v-if控制上一页和下一页是否显示,通过v-for遍历分页页码。
  • class绑定:通过v-bind:class绑定当前页的样式(active)。
  • @click.prevent指令:通过@click.prevent监听分页页码的点击事件。
  • {{}}标记:通过{{}}标记来显示分页页码。

下面我们根据这些关键点逐一解析。

前一页和后一页的控制

首先,我们需要根据当前页码数来确定上一页和下一页是否需要显示。根据模板中v-if的实现,我们可以知道v-if="current_page > 1"表示当前页码大于1时才显示上一页的按钮。

同理,v-if="current_page < last_page"表示当前页码小于最大页码时才显示下一页的按钮。

页码的遍历

接下来,我们需要在页面上展示分页的页码列表。根据模板中v-for的实现,我们可以知道v-for="page in pages"中的pages是Vue计算属性(computed)中返回的数组。

这里我们需要计算总共有多少页,以及页码列表中需要展示哪些页码。我们使用Vue计算属性来实现:

computed: {
  pages: function() {
    var pages = [];
    for (var i = this.current_page - this.offset; i <= this.current_page + this.offset; i++) {
      if (i > 0 && i <= this.last_page) {
        pages.push(i);
      }
    }
    return pages;
  }
}
로그인 후 복사

其中,pages是页码列表,current_page是当前页码,last_page是最大页码。offset是偏移量,表示当前页码的左右各展示几个页码。

通过计算,我们得到页码列表中应该展示哪些页码。然后在模板中使用v-for遍历计算得到的页码,将列表展示在页面上。

样式的绑定

为了让当前页码的样式显得与众不同,我们需要在模板中给当前页加上指定的class。在模板中,我们使用v-bind:class来实现这个功能。

<li v-for="page in pages"
    v-bind:class="[ page == current_page ? 'active' : '' ]">
  <a href=""
     @click.prevent="changePage(page)">@{{ page }}</a>
</li>
로그인 후 복사

在这段代码中,v-bind:class绑定了一个数组。数组中有两个元素。第一个是判断当前页码与遍历到的页码是否相等,如果相等,则绑定一个active的class,表示当前页码。如果不相等,则绑定一个空字符串的class。通过这个方式,我们就可以实现给当前页码绑定指定的样式。

点击事件的监听

当用户点击某一页码时,我们需要获取该页码并进行相应的跳转或者数据请求等操作。在Vue中,我们通过@click.prevent来注册点击事件并阻止默认行为。

<a href=""
   @click.prevent="changePage(page)">@{{ page }}</a>
로그인 후 복사

这里的changePage是一个方法,我们在Vue实例中定义这个方法。

methods: {
  changePage: function(page) {
    this.current_page = page;
    this.$emit('page-changed', page);
  }
}
로그인 후 복사

在这个方法中,我们更新当前页码并触发(emit)一个自定义事件page-changedclass 바인딩: v-bind:class를 통해 현재 페이지(활성)의 스타일을 바인딩합니다.

@click.prevent 명령: 페이지 매김 페이지 번호의 클릭 이벤트를 모니터링하려면 @click.prevent를 사용하세요.

{{}} 태그: {{}} 태그를 사용하여 페이지 매기기 페이지 번호를 표시합니다.

이러한 핵심 사항을 하나씩 분석해 보겠습니다.

이전 페이지와 다음 페이지 제어🎜🎜먼저 현재 페이지 번호를 기준으로 이전 페이지와 다음 페이지를 표시할지 여부를 결정해야 합니다. 템플릿의 v-if 구현에 따르면 v-if="current_page > 1"은 이전 페이지의 버튼이 현재 페이지 번호가 1보다 큰 경우에만 표시됩니다. 🎜🎜마찬가지로 v-if="current_page < last_page"는 현재 페이지 번호가 최대 페이지 번호보다 작은 경우에만 다음 페이지 버튼이 표시된다는 의미입니다. 🎜🎜페이지 번호 순회🎜🎜다음으로 페이지에 페이지 번호 목록을 표시해야 합니다. 템플릿의 v-for 구현에 따르면 v-for="page in Pages"pages가 Vue 계산된 속성(계산됨). 🎜🎜여기서 총 페이지 수와 페이지 번호 목록에 표시되어야 하는 페이지 번호를 계산해야 합니다. 이를 달성하기 위해 Vue 계산 속성을 사용합니다. 🎜rrreee🎜 그중 pages는 페이지 번호 목록이고 current_page는 현재 페이지 번호이며 last_page는 최대 페이지 수입니다. <code>오프셋은 현재 페이지 번호의 왼쪽과 오른쪽에 표시되는 페이지 번호 수를 나타내는 오프셋입니다. 🎜🎜계산을 통해 페이지 번호 목록에 어떤 페이지 번호를 표시해야 하는지 알아냅니다. 그런 다음 템플릿에서 v-for를 사용하여 계산된 페이지 번호를 탐색하고 페이지에 목록을 표시합니다. 🎜🎜스타일 바인딩🎜🎜현재 페이지 번호의 스타일을 고유하게 만들려면 템플릿의 현재 페이지에 지정된 클래스를 추가해야 합니다. 템플릿에서는 v-bind:class를 사용하여 이 함수를 구현합니다. 🎜rrreee🎜이 코드에서 v-bind:class는 배열을 바인딩합니다. 배열에는 두 개의 요소가 있습니다. 첫 번째는 현재 페이지 번호가 순회한 페이지 번호와 같은지 확인하는 것입니다. 동일한 경우 active 클래스를 바인딩하여 현재 페이지 번호를 나타냅니다. 같지 않으면 빈 문자열 클래스를 바인딩합니다. 이러한 방식으로 지정된 스타일을 현재 페이지 번호에 바인딩할 수 있습니다. 🎜🎜클릭 이벤트 모니터링🎜🎜사용자가 특정 페이지 번호를 클릭하면 페이지 번호를 가져와 해당 점프나 데이터 요청을 수행해야 합니다. Vue에서는 @click.prevent를 사용하여 클릭 이벤트를 등록하고 기본 동작을 방지합니다. 🎜rrreee🎜changePage 여기에 메소드가 있습니다. Vue 인스턴스에서 이 메소드를 정의합니다. 🎜rrreee🎜이 방법에서는 현재 페이지 번호를 업데이트하고 맞춤 이벤트 page-changed를 트리거(발산)합니다. 이 사용자 정의 이벤트를 통해 상위 구성 요소의 이벤트를 수신하고 특정 작업을 구현할 수 있습니다. 🎜🎜Summary🎜🎜위의 분석을 통해 Vue 페이징 바 구성 요소의 구현이 비교적 간단하다는 것을 알 수 있습니다. 하지만 이 구성 요소의 기본 원리를 익히면 Vue 프레임워크를 보다 능숙하게 사용할 수 있으며 실제 개발에서 페이징 기능을 보다 유연하고 편리하게 적용할 수 있습니다. 🎜

위 내용은 Vue 문서의 페이징 바 구성 요소 구현 프로세스에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿