前端代替后端做分页操作

复制代码
如果后端没有分页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的长度。
到这里应该已经实现了前端分页功能
相关推荐
Aphasia31117 分钟前
react必备JavaScript知识点(二)——类
前端·javascript
玖玖passion19 分钟前
数组转树:数据结构中的经典问题
前端
呼Lu噜25 分钟前
WPF-遵循MVVM框架创建图表的显示【保姆级】
前端·后端·wpf
珠峰下的沙砾28 分钟前
Vue3 里 CSS 深度作用选择器 :global
前端·javascript·css
航Hang*30 分钟前
WEBSTORM前端 —— 第2章:CSS —— 第3节:背景属性与显示模式
前端·css·css3·html5·webstorm
wuhen_n32 分钟前
CSS元素动画篇:基于当前位置的变换动画(一)
前端·css·html·css3·html5
拉不动的猪1 小时前
# 移动端与PC端全屏的处理
前端·javascript·面试
局外人LZ1 小时前
WXT+Vue3+sass+antd+vite搭建项目开发chrome插件
前端·chrome·vue·sass
excel1 小时前
招幕技术人员
前端·javascript·后端
专注VB编程开发20年2 小时前
jss html5-node.nodeType 属性用于表示节点的类型
前端·js