当前位置: 首页 > news >正文

PageHelper组件 实现前端分页查询功能

Hi~!这里是一颗小谷粒,很荣幸您能阅读我的文章,诚请评论指点,欢迎欢迎 ~~
💥💥个人主页:一颗小谷粒
💥💥所属专栏:Web前端开发

💥💥博主微信:g2279605572  

🚀本系列文章为个人学习笔记,在这里撰写成文一为巩固知识,二为记录我的学习过程及理解。文笔、排版拙劣,望见谅。    

目录

一、后端引入PageHelper插件

1.1 在 pom.xml 文件中添加依赖

1.2 在 application.yml 文件配置    

1.3 在Service层调用

二、前端使用分页组件 

2.1 使用ElementUI分页组件 

2.2 前端分页代码解析

 2.3 我的源码


一、后端引入PageHelper插件

1.1 在 pom.xml 文件中添加依赖

        <!-- pagehelper依赖 --><dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper-spring-boot-starter</artifactId><version>1.2.5</version></dependency>

如图所示:

1.2 在 application.yml 文件配置    

开启spring循环依赖支持,注意是在spring级配置: 

  main:allow-circular-references: true #开始支持spring循环依赖

如图所示: 

1.3 在Service层调用

    public PageInfo<Admin> admins(Admin admin){PageHelper.startPage(admin.getPageNo(), admin.getPageSize()); //1.会自动算出limit后面的开始位置List<Admin> admins =  adminDao.admins(admin);                 //2.重新发一条sql,查询总条数PageInfo<Admin> pageInfo = new PageInfo<>(admins);return pageInfo;}

如图所示: 

二、前端使用分页组件 

2.1 使用ElementUI分页组件 

完整功能分页组件代码:

    <el-pagination@size-change="handleSizeChange"@current-change="handleCurrentChange":current-page="currentPage4":page-sizes="[100, 200, 300, 400]":page-size="100"layout="total, sizes, prev, pager, next, jumper":total="400"></el-pagination>methods: {handleSizeChange(val) {console.log(`每页 ${val} 条`);},handleCurrentChange(val) {console.log(`当前页: ${val}`);}}

前端分页组件完成的工作:

  1. 可以根据总条数和每页显示的条数,计算出总页数。
  2. 通过组件显示分页的样式。
  3. 通过组件可以改变当前页数和页数大小。

2.2 前端分页代码解析

 2.3 我的源码

<template><div><div style="color: #2c9678"><h2>管理员管理</h2></div><br /><hr /><br /><el-card class="box-card"><!-- 查询条件--><el-row :gutter="20"><el-col :span="6"><el-input placeholder="请输入账号" v-model="form.account"></el-input></el-col><el-col :span="6"><el-radio label="男" v-model="form.gender">男</el-radio><el-radio label="女" v-model="form.gender">女</el-radio></el-col><el-col :span="6"><el-button type="primary" icon="el-icon-search" @click="search()">查询</el-button></el-col></el-row><br /><el-button type="primary" icon="el-icon-plus">新增</el-button><el-table :data="tableData" border style="width: 100%"><el-table-column prop="account" label="账号" width="100"></el-table-column><el-table-column prop="gender" label="性别" width="100"></el-table-column><el-table-column prop="phone" label="电话" width="150"></el-table-column><el-table-column prop="admin.account" label="操作人"></el-table-column><el-table-column prop="operTime" label="操作时间" align="center"></el-table-column><el-table-column label="操作" fixed="right"><template slot-scope="scope"><el-button size="mini">编辑</el-button><el-button size="mini" type="danger">删除</el-button></template></el-table-column></el-table><el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange":current-page="form.pageNo" :page-sizes="[2, 4, 6, 10]" :page-size="2"layout="total, sizes, prev, pager, next, jumper" :total="total"></el-pagination></el-card></div>
</template><script>export default {data() {return {tableData: [],total:0,form: {account: "",gender: "",pageNo: 1,pageSize: 2}}},methods: {search() {this.admins();},admins() {this.$http.post("adminCtl/admins", this.form).then((resp) => {this.tableData = resp.data.result.list;this.total = resp.data.result.total;})},handleSizeChange(val) { //当改变下拉框页数大小时触发this.form.pageSize = val;this.form.pageNo = 1;this.admins();},handleCurrentChange(val) { //当改变当前页数时触发this.form.pageNo = val;this.admins();}},mounted() {//向后端发送请求,查询管理员信息列表this.admins();}}
</script><style>
</style>

 效果: 




本次的分享就到此为止了,希望我的分享能给您带来帮助,创作不易也欢迎大家三连支持,你们的点赞就是博主更新最大的动力!如有不同意见,欢迎评论区积极讨论交流,让我们一起学习进步!有相关问题也可以私信博主,评论区和私信都会认真查看的,我们下次再见 

http://www.lryc.cn/news/432312.html

相关文章:

  • 线性回归与逻辑回归在模型参数优化上的比较
  • JavaWeb JavaScript 10.日程管理 第一期
  • redis为什么快
  • 十分钟学会Kubernetes(K8S) 部署SpringBoot3.0
  • 顺序表的插入与删除
  • FFMPEG -- 音频开发
  • lxml官方入门教程(The lxml.etree Tutorial)翻译
  • string详解
  • 基于约束大于规范的想法,封装缓存组件
  • 自动化测试面试真题(附答案)
  • 云原生架构概念
  • 85、 探针
  • 2024全国大学省数学建模竞赛A题-原创参考论文(部分+第一问代码)
  • 在VScode上写网页(html)
  • C#中LINQ的Cast<T>与OfType<T>
  • 小阿轩yx-Kubernertes日志收集
  • 0to1使用Redis实现“登录验证”次数限制
  • ARM----时钟
  • NISP 一级 —— 考证笔记合集
  • C++三位状态比较排序
  • 麒麟系统安装GPU驱动
  • IDEA 安装lombok插件不兼容的问题及解决方法
  • 聊聊说话的习惯
  • 当水泵遇上物联网:智能水务新时代的浪漫交响
  • 【Canvas与钟表】干支表盘
  • 分布式项目中使用雪花算法提前获取对象主键ID
  • 小程序多个set-cookie无法处理
  • Mybatis【分页插件,缓存,一级缓存,二级缓存,常见缓存面试题】
  • 【Qt开发】QT6.5.3安装方法(使用国内源)亲测可行!!!
  • springblade-JWT认证缺陷漏洞CVE-2021-44910