前端代替后端做分页操作

复制代码
如果后端没有分页api,前端如何做分页

一、使用computed

复制代码
这个变量应该是计算之后的值,是一个状态管理变量,跟onMounted类似
ts 复制代码
import {computed} from 'vue'
// 定义ref储存rolelist,这里是原始数据
const roleList = ref([])

// 定义页码
let pageIndex = ref(1)
// 定义显示的列表
let showRoles = computed(() => {
	// 切片操作
	return roles.value.slice((pageIndex.value-1) * 10, pageIndex)
})

// 查询数据操作,自己写
复制代码
将showRoles替换绑定表格数据,我这里是组件,是父传子定义的一个变量tableData,如果你这里插入的是一个表格,那么应该是:Data="showRoles"
html 复制代码
	<PublicTables :tableData="showRoles" @multipleSelection="handleSelection">

                <!-- <template #selection ></template> -->

                <template #tableColumn>

                    <el-table-column property="roleId" label="角色ID" />

                    <el-table-column property="roleName" label="角色名" />

                </template>

                <template #operation>

                    <el-table-column label="操作">

                        <template #default="scope">

                            <el-button size="small" @click="handleEdit(scope.row)">

                                编辑

                            </el-button>

                            <el-button size="small" type="danger" @click="handleDelete(scope.row)">

                                删除

                            </el-button>

                        </template>

                    </el-table-column>

                </template>

            </PublicTables>

二、添加分页器

复制代码
template中添加分页器
html 复制代码
	<el-pagination size="small" background layout=" prev, pager, next, total" :total="roleList.length" :current-page="pageIndex" />
复制代码
这里current-page绑定绑定的页码会保持同步,分页器总页数就是roleList的长度。
到这里应该已经实现了前端分页功能
相关推荐
玫城3 小时前
[ VUE ] 封装通用数组校验组件,el-input内使用
前端·javascript·vue.js
南半球与北海道#7 小时前
前端打印(三联纸票据打印)
前端·vue.js·打印
董世昌417 小时前
深入浅出 JavaScript 常用事件:从原理到实战的全维度解析
前端
满栀5858 小时前
分页插件制作
开发语言·前端·javascript·jquery
qq_406176148 小时前
深入剖析JavaScript原型与原型链:从底层机制到实战应用
开发语言·前端·javascript·原型模式
开开心心_Every9 小时前
免费窗口置顶小工具:支持多窗口置顶操作
服务器·前端·学习·macos·edge·powerpoint·phpstorm
闲蛋小超人笑嘻嘻9 小时前
Vue 插槽:从基础到进阶
前端·javascript·vue.js
梦6509 小时前
Vue2 与 Vue3 对比 + 核心差异
前端·vue.js
tiandyoin9 小时前
给 MHTML 添加滚动条.mhtml
前端·chrome·html·mhtml
遗憾随她而去.10 小时前
前端大文件上传(切片并发/断点续传/秒传/WebWorker 计算Hash) 含完整代码
前端