목차
前一页和后一页的控制
页码的遍历
样式的绑定
点击事件的监听
웹 프론트엔드 View.js Vue 문서의 페이징 바 구성 요소 구현 프로세스에 대한 자세한 설명

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

Jun 20, 2023 am 09:15 AM
vue 구성 요소 쪽수 매기기

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
1 몇 달 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Vue 용 버튼에 기능을 추가하는 방법 Vue 용 버튼에 기능을 추가하는 방법 Apr 08, 2025 am 08:51 AM

HTML 템플릿의 버튼을 메소드에 바인딩하여 VUE 버튼에 함수를 추가 할 수 있습니다. 메소드를 정의하고 VUE 인스턴스에서 기능 로직을 작성하십시오.

Vue에서 부트 스트랩을 사용하는 방법 Vue에서 부트 스트랩을 사용하는 방법 Apr 07, 2025 pm 11:33 PM

vue.js에서 bootstrap 사용은 5 단계로 나뉩니다 : Bootstrap 설치. main.js.의 부트 스트랩 가져 오기 부트 스트랩 구성 요소를 템플릿에서 직접 사용하십시오. 선택 사항 : 사용자 정의 스타일. 선택 사항 : 플러그인을 사용하십시오.

vue.js로 JS 파일을 참조하는 방법 vue.js로 JS 파일을 참조하는 방법 Apr 07, 2025 pm 11:27 PM

vue.js에서 JS 파일을 참조하는 세 가지 방법이 있습니다. & lt; script & gt; 꼬리표;; mounted () 라이프 사이클 후크를 사용한 동적 가져 오기; Vuex State Management Library를 통해 수입.

Vue에서 시계를 사용하는 방법 Vue에서 시계를 사용하는 방법 Apr 07, 2025 pm 11:36 PM

vue.js의 시계 옵션을 사용하면 개발자가 특정 데이터의 변경 사항을들을 수 있습니다. 데이터가 변경되면 콜백 기능을 트리거하여 업데이트보기 또는 기타 작업을 수행합니다. 구성 옵션에는 즉시 콜백을 실행할지 여부와 DEEP를 지정하는 즉시 포함되며, 이는 객체 또는 어레이에 대한 변경 사항을 재귀 적으로 듣는 지 여부를 지정합니다.

Vue가 이전 페이지로 돌아 오는 방법 Vue가 이전 페이지로 돌아 오는 방법 Apr 07, 2025 pm 11:30 PM

vue.js는 이전 페이지로 돌아갈 수있는 네 가지 방법이 있습니다. $ router.go (-1) $ router.back () 사용 & lt; router-link to = & quot;/quot; Component Window.history.back () 및 메소드 선택은 장면에 따라 다릅니다.

Vue는 천막/텍스트 스크롤 효과를 인식합니다 Vue는 천막/텍스트 스크롤 효과를 인식합니다 Apr 07, 2025 pm 10:51 PM

CSS 애니메이션 또는 타사 라이브러리를 사용하여 VUE에서 Marquee/Text Scrolling Effects를 구현하십시오. 이 기사는 CSS 애니메이션 사용 방법을 소개합니다. & lt; div & gt; CSS 애니메이션을 정의하고 오버플로를 설정하십시오 : 숨겨진, 너비 및 애니메이션. 키 프레임을 정의하고 변환을 설정하십시오 : Translatex () 애니메이션의 시작과 끝에서. 지속 시간, 스크롤 속도 및 방향과 같은 애니메이션 속성을 조정하십시오.

Vue Pagination 사용 방법 Vue Pagination 사용 방법 Apr 08, 2025 am 06:45 AM

Pagination은 큰 데이터 세트를 작은 페이지로 나누어 성능 및 사용자 경험을 향상시키는 기술입니다. VUE에서 다음 내장 방법을 페이징에 사용할 수 있습니다. 총 페이지 수를 계산하십시오 : TotalPages () Traversal 페이지 번호 : V-For Directive 현재 페이지를 설정하려면 : CurrentPage 현재 페이지 데이터 가져 오기 : currentPagedAta ()

함수 인터셉트 vue를 사용하는 방법 함수 인터셉트 vue를 사용하는 방법 Apr 08, 2025 am 06:51 AM

VUE의 기능 차단은 지정된 기간 내에 기능이 호출되는 횟수를 제한하고 성능 문제를 방지하는 데 사용되는 기술입니다. 구현 방법은 다음과 같습니다. lodash 라이브러리 가져 오기 : 'lodash'에서 import {debounce}; Debounce 기능을 사용하여 인터셉트 기능을 만듭니다. const debouncedfunction = debounce (() = & gt; { / logical /}, 500); 인터셉트 함수를 호출하면 제어 기능이 최대 500 밀리 초 안에 한 번 호출됩니다.

See all articles