Vue分页组件封装的实现是怎样的,代码是什么
Admin 2022-08-13 群英技术资讯 950 次浏览
这篇文章给大家分享的是“Vue分页组件封装的实现是怎样的,代码是什么”,对大家学习和理解有一定的参考价值和帮助,有这方面学习需要的朋友,接下来就跟随小编一起学习一下吧。这个是基于vue2的分页封装,仿照elementUI而写的组件。
效果如图

话不多说,直接上代码
<template>
<div class="pagination">
<!-- 总页数 -->
<div class="total">共{{ total }}条</div>
<!-- 选择每页的条数 -->
<select name="" id="size_select" v-model="sizes" @change="sizeChange">
<option v-for="item in pageSizes" :key="item" :value="item">
{{ item }}条/页
</option>
</select>
<div class="pagenum">
<!-- 上一页 -->
<el-button
icon="el-icon-arrow-left"
:disabled="backDisabled"
circle
@click="back"
></el-button>
<!-- 页码 -->
<ul>
<li
:class="currentPage == item ? 'active' : ''"
v-for="(item, index) in pagenum"
:key="index"
@click="toPage(item)"
>
{{ item }}
</li>
</ul>
<!-- 下一页 -->
<el-button
icon="el-icon-arrow-right"
:disabled="forwardDisabled"
circle
@click="forward"
></el-button>
</div>
</div>
</template>
<script>
export default {
name: "pagination",
props: {
total: { // 总数
type: null,
required: true,
},
pageSizes: { // 可选择的每页条数
type: Array,
},
pageSize: { // 每页显示的条数
type: Number,
required: true,
},
currentPage: { // 当前页
type: Number,
required: true,
},
},
data() {
return {
sizes: this.pageSize, // 接收props传来的pageSize
nowPage: this.currentPage, // 接收props传来的currentPage
};
},
computed: {
allPage() { // 计算所有的页数
return Math.ceil(this.total / this.pageSize);
},
backDisabled() { // 是否禁用上一页
return this.currentPage == 1;
},
forwardDisabled() { // 是否禁用下一页
return this.currentPage == this.allPage;
},
pagenum() { // 计算显示不同的页
if (this.allPage - this.nowPage > 6) { //
if (this.nowPage > 6) {
return [
1,
"...",
this.nowPage - 2,
this.nowPage - 1,
this.nowPage,
this.nowPage + 1,
this.nowPage + 2,
"...",
this.allPage,
];
} else {
if (this.allPage > 8) {
return [1, 2, 3, 4, 5, 6, "...", this.allPage];
} else {
return this.allPage;
}
}
} else {
if (this.nowPage < 6) {
return this.allPage;
} else {
return [
1,
"...",
this.allPage - 5,
this.allPage - 4,
this.allPage - 3,
this.allPage - 2,
this.allPage - 1,
this.allPage,
];
}
}
},
},
methods: {
sizeChange() { // 每页限制条数改变触发事件
this.$emit("sizeChange", this.sizes);
},
forward() { // 点击下一页
this.$emit("currentChange", (this.nowPage += 1));
},
back() { // 点击上一页
this.$emit("currentChange", (this.nowPage -= 1));
},
toPage(val) { // 点击页数
if (val == "...") {
console.log(2);
} else {
this.nowPage = val;
this.$emit("currentChange", val);
}
},
},
};
</script>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Vue Router 是 Vue.js 官方的路由管理器。它和 Vue.js 的核心深度集成,让构建单页面应用变得易如反掌。本文介绍下Vue Router的安装与使用
遇到一个需求,在一个地铁场景里展示逃生路线,为了画这个箭头,我花费了很多时间精力,下面基于使用three.js 绘制三维带箭头线的详细过程分享给大家,感兴趣的朋友一起看看吧
JS中异步和单线程是什么?对于新手来说,可能不是很了解异步和单线程,因此下文小编就给大家来简单的介绍一下什么是异步和单线程,对帮大家学习和理解JavaScript的异步和单线程一定的帮助,感兴趣的朋友就继续往下看吧。
这篇文章我们来了解jQuery触发change事件的方法,手动触发改变事件我们需要使用到change()方法,接下来我们通过示例来了解change()方法的使用及触发改变事件的实现,感兴趣的朋友就继续往下看吧。
在前端开发时,点击父菜单弹出子菜单功能是比较经常遇到需求,这篇文章就主要介绍用JavaScript实现点击出现子菜单,以下是简易的实现效果以及具体代码展示,感兴趣的朋友就继续往下看吧。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008