import{o as s,a,y as n}from"./vue-libs.b44bc779.js";const e={class:"van-doc-markdown-body"},d=n(`
When the amount of data is too much, use pagination to separate the data, and load only one page at a time.
Register component globally via app.use
, refer to Component Registration for more registration ways.
import { createApp } from 'vue';
import { Pagination } from 'vant';
const app = createApp();
app.use(Pagination);
<van-pagination v-model="currentPage" :total-items="24" :items-per-page="5" />
import { ref } from 'vue';
export default {
setup() {
const currentPage = ref(1);
return { currentPage };
},
};
<van-pagination v-model="currentPage" :page-count="12" mode="simple" />
<van-pagination
v-model="currentPage"
:total-items="125"
:show-page-size="3"
force-ellipses
/>
<van-pagination v-model="currentPage" :total-items="50" :show-page-size="5">
<template #prev-text>
<van-icon name="arrow-left" />
</template>
<template #next-text>
<van-icon name="arrow" />
</template>
<template #page="{ text }">{{ text }}</template>
</van-pagination>
Attribute | Description | Type | Default |
---|---|---|---|
v-model | Current page number | number | - |
mode | Mode, can be set to simple multi | string | multi |
prev-text | Previous text | string | Previous |
next-text | Next text | string | Next |
total-items | Total items | number | string | 0 |
items-per-page | Item number per page | number | string | 10 |
page-count | The total number of pages, if not set, will be calculated based on total-items and items-per-page | number | string | - |
show-page-size | Count of page size to show | number | string | 5 |
force-ellipses | Whether to show ellipses | boolean | false |
Event | Description | Arguments |
---|---|---|
change | Emitted when current page changed | - |
Name | Description | SlotProps |
---|---|---|
page | Custom pagination item | { number: number, text: string, active: boolean } |
prev-text | Custom prev text | - |
next-text | Custom next text | - |
The component exports the following type definitions:
import type { PaginationMode, PaginationProps } from 'vant';
The component provides the following CSS variables, which can be used to customize styles. Please refer to ConfigProvider component.
Name | Default Value | Description |
---|---|---|
--van-pagination-height | 40px | - |
--van-pagination-font-size | var(--van-font-size-md) | - |
--van-pagination-item-width | 36px | - |
--van-pagination-item-default-color | var(--van-primary-color) | - |
--van-pagination-item-disabled-color | var(--van-gray-7) | - |
--van-pagination-item-disabled-background-color | var(--van-background-color) | - |
--van-pagination-background-color | var(--van-background-color-light) | - |
--van-pagination-desc-color | var(--van-gray-7) | - |
--van-pagination-disabled-opacity | var(--van-disabled-opacity) | - |