Springboot结合Vue实现分页功能

前端:

javascript 复制代码
<el-pagination
      @size-change="handleSizeChange"
      @current-change="handleCurrentChange"
      :current-page="pageNum"
      :page-sizes="[10, 50, 100]"
      :page-size="pageSize"
      layout="total, sizes, prev, pager, next, jumper"
      :total="total">
</el-pagination>
javascript 复制代码
data(){
   return{
	total: 0,
	pageNum: 1, //初始页
	pageSize: 50, //    每页的数据
	}
}
javascript 复制代码
methods:{
    handleSizeChange: function (size) {
      this.pageSize= size;
      this.init();
    },
    handleCurrentChange: function (currentPage) {
      this.pageNum= currentPage;
      this.init();
    },
   init() {
  var params = new URLSearchParams();
      params.append("pageNum",this.currentPage);
      params.append("pageSize",this.pagesize);
      ...
      this.$axios
        .post(this.$api.getDataList, params)
        .then((res) => {
          if (res.code == 200) {
            this.tableData = res.data.list;
            this.total=res.data.total;
          } else if (res.code == 400) {
            this.$notify({
              title: "警告",
              message: res.msg,
              type: "warning",
            });
          } else {
            this.tableData = [];
          }
        })
        .catch((err) => {
          this.$notify.error({
            title: "错误",
            message: "出现系统错误,请联系管理员",
          });
          console.log(err);
        });
    },
}

后端:

pom文件添加依赖:

java 复制代码
<dependency>
    <groupId>com.github.pagehelper</groupId>
    <artifactId>pagehelper-spring-boot-starter</artifactId>
    <version>1.4.7</version>
 </dependency>
java 复制代码
public Result getDataList(DataDto dataDto,Integer pageNum,Integer pageSize) {
        Result r = new Result();
        try {

            PageHelper.startPage(pageNum, pageSize);
            List<DataDto> dataList= dataDao.getDataList(dataDto);
            PageInfo<DataDto> pageInfo = new PageInfo<>(dataList);
            Integer total= Math.toIntExact(pageInfo.getTotal());
            List<DataDto> list=pageInfo.getList();
            if (list.size()> 0) {
                r.setCode(200);
                r.setMsg("查询成功");
                Map<String,Object> map=new HashMap<>();
                map.put("list",list);
                map.put("total",total);
                r.setData(map);
            } else {
                r.setCode(300);
                r.setMsg("暂无数据");
            }
        } catch (Exception e) {
            e.printStackTrace();
            r.setCode(400);
            r.setMsg("查询数据出现异常,请联系管理员");
        }
        return r;
}
相关推荐
Soofjan1 分钟前
sync.Mutex源码
后端
极客小云9 分钟前
【Electron-Vue 企业级安全启动模板:electron-vue-theme-template 使用指南】
vue.js·安全·electron
计算机学姐14 分钟前
基于SpringBoot的校园二手书籍交易系统【个性化推荐+数据可视化统计+我买到的+我卖出的】
vue.js·spring boot·后端·mysql·信息可视化·intellij-idea·mybatis
SuperEugene14 分钟前
Vue3 + Element Plus 表单开发实战:防重复提交、校验、重置、loading 统一|表单与表格规范篇
前端·javascript·vue.js
SuperEugene16 分钟前
Vue3 + Element Plus 中后台弹窗规范:开闭、传参、回调,告别弹窗地狱|Vue 组件与模板规范篇
开发语言·前端·javascript·vue.js·前端框架
神奇小汤圆17 分钟前
JDK17 前后写法对比:差点没认出是 Java!
后端
SuperEugene19 分钟前
VXE-Table 4.x 实战规范:列配置 + 合并单元格 + 虚拟滚动,避坑卡顿 / 错乱 / 合并失效|表单与表格规范篇
开发语言·前端·javascript·vue.js·前端框架·vxetable
偷懒下载原神19 分钟前
【linux操作系统】信号
linux·运维·服务器·开发语言·c++·git·后端
SmartBrain27 分钟前
Spring Boot 中常用注解总结(AI工程化)
java·人工智能·spring boot·后端
小江的记录本39 分钟前
【Redis】Redis常用命令速查表(完整版)
java·前端·数据库·redis·后端·spring·缓存