codecamp

Vant3 Pagination 分页

介绍

数据量过多时,采用分页的形式将数据分隔,每次只加载一个页面。

实例演示

引入

通过以下方式来全局注册组件,更多注册方式请参考组件注册

import { createApp } from 'vue';
import { Pagination } from 'vant';

const app = createApp();
app.use(Pagination);

代码演示

基础用法

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

<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 };
  },
};

简单模式

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

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

显示省略号

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

<van-pagination
  v-model="currentPage"
  :total-items="125"
  :show-page-size="3"
  force-ellipses
/>

自定义按钮

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

<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>

API

Props

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

Events

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

Slots

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

样式变量

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

名称 默认值 描述
--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-white) -
--van-pagination-desc-color var(--van-gray-7) -
--van-pagination-disabled-opacity var(--van-disabled-opacity) -


Vant3 NavBar 导航栏
Vant3 Sidebar 侧边导航
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

Vant3 废弃内容

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }