Pagination
Usage
Use the default-page
prop or the v-model:page
directive to control the current page.
color
, variant
and size
props to style them.Total
Use the total
prop to set the total number of items in the list.
<script setup lang="ts">
const page = ref(5)
</script>
<template>
<UPagination v-model:page="page" :total="100" />
</template>
Items Per Page
Use the items-per-page
prop to set the number of items per page. Defaults to 10
.
<script setup lang="ts">
const page = ref(5)
</script>
<template>
<UPagination v-model:page="page" :items-per-page="20" :total="100" />
</template>
Sibling Count
Use the sibling-count
prop to set the number of siblings to show. Defaults to 2
.
<script setup lang="ts">
const page = ref(5)
</script>
<template>
<UPagination v-model:page="page" :sibling-count="1" :total="100" />
</template>
Show Edges
Use the show-edges
prop to always show the ellipsis, first and last pages. Defaults to false
.
<script setup lang="ts">
const page = ref(5)
</script>
<template>
<UPagination v-model:page="page" show-edges :sibling-count="1" :total="100" />
</template>
Show Controls
Use the show-controls
prop to show the first, prev, next and last buttons. Defaults to true
.
<script setup lang="ts">
const page = ref(5)
</script>
<template>
<UPagination v-model:page="page" :showControls="false" show-edges :total="100" />
</template>
Color
Use the color
prop to set the color of the inactive controls. Defaults to neutral
.
<script setup lang="ts">
const page = ref(5)
</script>
<template>
<UPagination v-model:page="page" color="primary" :total="100" />
</template>
Variant
Use the variant
prop to set the variant of the inactive controls. Defaults to outline
.
<script setup lang="ts">
const page = ref(5)
</script>
<template>
<UPagination v-model:page="page" color="neutral" variant="subtle" :total="100" />
</template>
Active Color
Use the active-color
prop to set the color of the active control. Defaults to primary
.
<script setup lang="ts">
const page = ref(5)
</script>
<template>
<UPagination v-model:page="page" active-color="neutral" :total="100" />
</template>
Active Variant
Use the active-variant
prop to set the variant of the active control. Defaults to solid
.
<script setup lang="ts">
const page = ref(5)
</script>
<template>
<UPagination v-model:page="page" active-color="primary" active-variant="subtle" :total="100" />
</template>
Size
Use the size
prop to set the size of the controls. Defaults to md
.
<script setup lang="ts">
const page = ref(5)
</script>
<template>
<UPagination v-model:page="page" size="xl" :total="100" />
</template>
Disabled
Use the disabled
prop to disable the pagination controls.
<script setup lang="ts">
const page = ref(5)
</script>
<template>
<UPagination v-model:page="page" :total="100" disabled />
</template>
Examples
With links
Use the to
prop to transform buttons into links. Pass a function that receives the page number and returns a route destination.
<script setup lang="ts">
const page = ref(5)
function to(page: number) {
return {
query: {
page
},
hash: '#with-links'
}
}
</script>
<template>
<UPagination v-model:page="page" :total="100" :to="to" :sibling-count="1" show-edges />
</template>
#with-links
hash to avoid going to the top of the page.API
Props
Prop | Default | Type |
---|---|---|
as |
|
The element or component this component should render as. |
firstIcon |
|
The icon to use for the first page control. |
prevIcon |
|
The icon to use for the previous page control. |
nextIcon |
|
The icon to use for the next page control. |
lastIcon |
|
The icon to use for the last page control. |
ellipsisIcon |
|
The icon to use for the ellipsis control. |
color |
|
The color of the pagination controls. |
variant |
|
The variant of the pagination controls. |
activeColor |
|
The color of the active pagination control. |
activeVariant |
|
The variant of the active pagination control. |
showControls |
|
Whether to show the first, previous, next, and last controls. |
size |
|
|
to |
A function to render page controls as links. | |
disabled |
When | |
page |
The controlled value of the current page. Can be binded as | |
defaultPage |
The value of the page that should be active when initially rendered. Use when you do not need to control the value state. | |
itemsPerPage |
|
Number of items per page |
showEdges |
|
When |
siblingCount |
|
Number of sibling should be shown around the current page |
total |
|
Number of items in your list |
ui |
|
Slots
Slot | Type |
---|---|
first |
|
prev |
|
next |
|
last |
|
ellipsis |
|
item |
|
Emits
Event | Type |
---|---|
update:page |
|
Theme
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import ui from '@nuxt/ui/vite'
export default defineConfig({
plugins: [
vue(),
ui({
ui: {
pagination: {
slots: {
root: '',
list: 'flex items-center gap-1',
ellipsis: 'pointer-events-none',
label: 'min-w-5 text-center'
}
}
}
})
]
})