Comment implémenter le composant de pagination dans Vue ?
Vue est un excellent framework front-end lors du traitement de grandes quantités de données, les composants de pagination sont essentiels. Le composant de pagination peut rendre la page plus ordonnée et également améliorer l'expérience utilisateur. Dans Vue, implémenter un composant de pagination n'est pas compliqué. Cet article présentera comment Vue implémente un composant de pagination.
1. Analyse des exigences
Avant de mettre en œuvre le composant de pagination, nous devons analyser les exigences. Un composant de pagination de base doit avoir les fonctions suivantes :
- Afficher le numéro de page actuel, le nombre total de pages et le nombre d'éléments affichés sur chaque page
- Cliquez sur le bouton de pagination pour passer à différents numéros de page
- Afficher le données de la page actuelle
- Le numéro de la page actuelle est élevé. Surligner
- Afficher le sélecteur de numéro de barre de pagination
2. Étapes de mise en œuvre
- Diviser les fichiers
Pour faciliter la gestion, nous divisons le composant de pagination en trois fichiers :
- Pagination.vue : composant de pagination Le fichier principal est principalement responsable de la logique et du traitement des événements.
- PaginationItem.vue : Un sous-composant du composant de pagination, principalement responsable du rendu du bouton de pagination.
- SelectPerPage.vue : composant de sélection d'éléments de pagination, principalement responsable du rendu de la liste déroulante de sélection d'éléments et de la gestion des événements de modification.
- Liaison des données de pagination
Nous devons définir certaines variables pour stocker les données liées à la pagination, notamment le numéro de page actuel, le nombre d'éléments par page et le nombre total de pages. Ces variables doivent être définies dans Pagination.vue. Dans le même temps, nous devons également introduire un attribut props pour recevoir les données transmises par le composant parent.
export default { props: { currentPage: { // 当前页码 type: Number, required: true }, total: { // 总记录数 type: Number, required: true }, perPage: { // 每页展示条数 type: Number, required: true } }, data () { return { pages: Math.ceil(this.total / this.perPage), // 总页数 pageList: [] // 存储当前页面展示的页码 } }, mounted () { this.getPageList(this.currentPage) } }
- Rendu du bouton de pagination
Nous divisons le bouton de pagination en un sous-composant, qui est principalement utilisé pour restituer le bouton de pagination et gérer les événements de changement de pagination. Le contenu de PaginationItem.vue est le suivant :
<template> <li :class="{ active: active }"> <a @click.prevent="handleClick" href="#"> {{ label }} </a> </li> </template> <script> export default { props: { label: { // 按钮上的数字或图标 required: true }, pageNum: { // 按钮代表的页码 required: true }, active: { // 判断按钮是否处于激活状态 default: false } }, methods: { // 点击分页按钮时触发 handleClick () { this.$emit('change', this.pageNum) } } } </script>
Dans Pagination.vue, nous devons utiliser la directive v-for pour restituer plusieurs composants PaginationItem.vue. Le nombre de pages doit être généré selon certaines règles. Pour cette règle, vous pouvez vous référer au code suivant :
methods: { // 获取当前页显示的页码 getPageList (currentPage) { let pageList = [] // 存储页码数据 const totalPages = this.pages // 总页数 const visiblePages = 5 // 按钮可见的页码数 const half = Math.floor(visiblePages / 2) // 可见页码数的一半 // 如果总页数小于可显示页数 if (totalPages <= visiblePages) { for (let i = 1; i <= totalPages; i++) { pageList.push(i) } } else { // 如果当前页码小于或等于可见页码数的一半 if (currentPage <= half) { for (let i = 1; i <= visiblePages; i++) { pageList.push(i) } } else if (currentPage >= totalPages - half) { // 如果当前页码大于等于最后一页减去可见页码数的一半 for (let i = totalPages - visiblePages + 1; i <= totalPages; i++) { pageList.push(i) } } else { for (let i = currentPage - half; i <= currentPage + half; i++) { pageList.push(i) } } } this.pageList = pageList } }
- Changement de pagination
Nous devons lier l'événement de changement de pagination au composant Pagination.vue. Cet événement doit être déclenché par le sous-composant PaginationItem.vue et transmettre le numéro de page commuté en paramètre.
Dans Pagination.vue, nous devons ajouter une nouvelle méthode nextPage pour mettre à jour le numéro de page actuel. Dans le même temps, nous devons également introduire un attribut calculé currentIndex pour obtenir l'index de la page en cours. Le code est le suivant :
methods: { // 点击页码时触发 handlePageChange (pageNum) { // 如果页码为负数或者大于总页数都停止执行 if (pageNum <= 0 || pageNum > this.pages) return this.currentPage = pageNum this.$emit('change-page', pageNum) // 事件广播向父组件传值 this.getPageList(pageNum) }, // 增加当前页码 nextPage () { if (this.currentIndex < this.pages - 1) { this.currentPage++ this.getPageList(this.currentPage) this.$emit('change-page', this.currentPage) // 事件广播向父组件传值 } } }, computed: { currentIndex () { // 当前页码所在的索引 return this.currentPage - 1 } }
- Boîte déroulante de sélection du numéro de page
Afin de permettre aux utilisateurs de changer le nombre d'enregistrements affichés sur chaque page, nous devons implémenter un composant de liste déroulante. Ce composant doit être implémenté par le fichier SelectPerPage.vue. Le contenu de
SelectPerPage.vue est le suivant :
<template> <div class="select-per-page"> <select :value="perPage" @change="changePerPage"> <option v-for="item in items" :value="item">{{ item }}</option> </select> </div> </template> <script> export default { props: { perPage: { // 每页展示条数 type: Number, required: true }, options: { // 可选的条数设置 type: Array, default () { return [10, 20, 30, 50] } } }, computed: { items () { return this.options.map(option => `${option} 条`) } }, methods: { // 切换每页展示的条数 changePerPage (event) { const perPage = +event.target.value.replace(/[D]/g, '') this.$emit('update:perPage', perPage) this.$emit('change-per-page', perPage) // 事件广播向父组件传值 } } } </script>
Ce qui précède est tout le contenu de Vue pour implémenter le composant de pagination. Nous devons introduire Pagination.vue dans le composant parent, puis transmettre les paramètres correspondants tels que currentPage, total et perPage. De cette manière, un composant de pagination réutilisable peut être implémenté, ce qui améliore l'efficacité et l'expérience de développement du développement front-end.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

L'utilisation de bootstrap dans vue.js est divisée en cinq étapes: installer bootstrap. Importer un bootstrap dans main.js. Utilisez le composant bootstrap directement dans le modèle. Facultatif: style personnalisé. Facultatif: utilisez des plug-ins.

Vous pouvez ajouter une fonction au bouton VUE en liant le bouton dans le modèle HTML à une méthode. Définissez la logique de la fonction de méthode et d'écriture dans l'instance Vue.

L'option Watch dans Vue.js permet aux développeurs d'écouter des modifications de données spécifiques. Lorsque les données changent, regardez déclenche une fonction de rappel pour effectuer des vues de mise à jour ou d'autres tâches. Ses options de configuration incluent immédiatement, qui spécifie s'il faut exécuter un rappel immédiatement, et profond, ce qui spécifie s'il faut écouter récursivement les modifications des objets ou des tableaux.

Le développement multi-pages VUE est un moyen de créer des applications à l'aide du cadre Vue.js, où l'application est divisée en pages distinctes: Maintenance du code: La division de l'application en plusieurs pages peut rendre le code plus facile à gérer et à maintenir. Modularité: chaque page peut être utilisée comme module séparé pour une réutilisation et un remplacement faciles. Routage simple: la navigation entre les pages peut être gérée par une configuration de routage simple. Optimisation du référencement: chaque page a sa propre URL, ce qui aide le référencement.

Il existe trois façons de se référer aux fichiers JS dans Vue.js: spécifiez directement le chemin à l'aide du & lt; script & gt; étiqueter;; importation dynamique à l'aide du crochet de cycle de vie monté (); et l'importation via la bibliothèque de gestion de l'État Vuex.

Vue.js dispose de quatre méthodes pour revenir à la page précédente: $ router.go (-1) $ router.back () utilise & lt; router-link to = & quot; / & quot; Composant Window.History.back (), et la sélection de la méthode dépend de la scène.

Il existe trois méthodes courantes pour que Vue.js traverse les tableaux et les objets: la directive V-FOR est utilisée pour traverser chaque élément et les modèles de rendu; La directive V-Bind peut être utilisée avec V-FOR pour définir dynamiquement les valeurs d'attribut pour chaque élément; et la méthode .map peut convertir les éléments du tableau en nouveaux tableaux.

Il existe deux façons de sauter des éléments div dans Vue: Utilisez le routeur Vue et ajoutez le composant routeur-link. Ajoutez l'écouteur de l'événement @Click et appelez ceci. $ Router.push () pour sauter.
