Pagination 分页

引入

  1. import { createApp } from 'vue';
  2. import { Pagination } from 'vant';
  3. const app = createApp();
  4. app.use(Pagination);

代码演示

基础用法

通过 v-model 来绑定当前页码。

  1. <van-pagination v-model="currentPage" :total-items="24" :items-per-page="5" />
  1. export default {
  2. data() {
  3. return {
  4. currentPage: 1,
  5. };
  6. },
  7. };

简单模式

 将 mode 设置为 simple 来切换到简单模式,此时分页器不会展示具体的页码按钮。

  1. <van-pagination v-model="currentPage" :page-count="12" mode="simple" />

显示省略号

设置 force-ellipses 后会展示省略号按钮,点击后可以快速跳转。

  1. <van-pagination
  2. v-model="currentPage"
  3. :total-items="125"
  4. :show-page-size="3"
  5. force-ellipses
  6. />

自定义按钮

通过 prev-textnext-text 等插槽来自定义分页按钮的内容。

  1. <van-pagination v-model="currentPage" :total-items="50" :show-page-size="5">
  2. <template #prev-text>
  3. <van-icon name="arrow-left" />
  4. </template>
  5. <template #next-text>
  6. <van-icon name="arrow" />
  7. </template>
  8. <template #page="{ text }">{{ text }}</template>
  9. </van-pagination>

API

Props

参数说明类型默认值
v-model当前页码number-
mode显示模式,可选值为 simplestringmulti
prev-text上一页按钮文字string上一页
next-text下一页按钮文字string下一页
page-count总页数number | string根据页数计算
total-items总记录数number | string0
items-per-page每页记录数number | string10
show-page-size显示的页码个数number | string5
force-ellipses是否显示省略号booleanfalse

Events

事件名说明回调参数
change页码改变时触发-

Slots

名称描述参数
page v2.10.9自定义页码{ number: number, text: string, active: boolean }
prev-text v2.10.9自定义上一页按钮文字-
next-text v2.10.9自定义下一页按钮文字-

样式变量

组件提供了下列 Less 变量,可用于自定义样式,使用方法请参考主题定制

名称默认值描述
@pagination-height40px-
@pagination-font-size@font-size-md-
@pagination-item-width36px-
@pagination-item-default-color@blue-
@pagination-item-disabled-color@gray-7-
@pagination-item-disabled-background-color@background-color-
@pagination-background-color@white-
@pagination-desc-color@gray-7-
@pagination-disabled-opacity@disabled-opacity-

Pagination 分页 - 图1