一个简易的的js分页插件

  html页面

<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<link rel="stylesheet" type="text/css" href="/plugins/page/page.css" />
</head>
<body>


<!-- 分页开始 -->
<div id="page_navigation">
    <input type="hidden" id="currentPage" th:value="${currentPage}">
    <input type="hidden" id="pageSize" th:value="${pageSize}">
    <input type="hidden" id="totalNum" th:value="${totalNum}">
    <input type="hidden" id="queryParams" th:value="${queryParams}">
</div>
<!-- 分页结束 -->

<script type="text/javascript" src="/plugins/page/page.js"></script>
</body>
</html>

样式page.css

#page_navigation{
  float: right;
  margin-top: 10px;
}
#page_navigation a{
    padding:3px;
    border:1px solid gray;
    margin:2px;
    color:black;
    text-decoration:none
}
#page_navigation .active_page{
    background:darkblue;
    color:white !important;
}

 js脚本文件

$(document).ready(function(){

    //每页显示的数目
    var pageSize = $('#pageSize').val();
    //获取总的数据量
    var totalNum = $('#totalNum').val();
    //当前页  
    var currentPage = $('#currentPage').val();


    //计算页面显示的数量
    var number_of_pages = Math.ceil(totalNum/pageSize);

    var navigation_html = '<a class="previous_link" href="javascript:previous();">上一页</a>';
    var current_link = 0;
    while(number_of_pages > current_link){
        navigation_html += '<a class="page_link" href="javascript:go_to_page(' + current_link +')" longdesc="' + current_link +'">'+ (current_link + 1) +'</a>';
        current_link++;
    }
    navigation_html += '<a class="next_link" href="javascript:next();">下一页</a>';

    $('#page_navigation').html(navigation_html);

    /*get the page link that has longdesc attribute of the current page and add active_page class to it
    and remove that class from previously active page link*/
    $('.page_link[longdesc=' + currentPage +']').addClass('active_page').siblings('.active_page').removeClass('active_page');


});

//上一页
function previous(){
    new_page = parseInt($('#currentPage').val()) - 1;
    //if there is an item before the current active link run the function
    if($('.active_page').prev('.page_link').length==true){
        go_to_page(new_page);
    }

}
//下一页
function next(){
    new_page = parseInt($('#currentPage').val()) + 1;
    //if there is an item after the current active link run the function
    if($('.active_page').next('.page_link').length==true){
        go_to_page(new_page);
    }

}
//跳转某一页
function go_to_page(page_num){
   var queryParams = $('#queryParams').val();
   window.location.href="/app?page="+page_num+"&"+queryParams;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot是一个用于快速开发Java应用程序的框架,它基于Spring框架,并提供了自动配置和约定优于配置的原则。分页件是在Spring Boot中实现分页功能的一种方式,可以方便地对数据库查询结果进行分页处理。 要手写一个分页件,你可以按照以下步骤进行: 1. 创建一个Page类,用于封装分页相关的信息,如当前页码、每页显示数量、总记录数等。 2. 在数据库查询方法中,根据传入的Page对象,使用limit语句限制查询结果的范围,实现分页功能。 3. 在业务层或控制层中,根据用户请求的页码和每页显示数量,创建Page对象,并将其传递给数据库查询方法。 4. 在前端页面中,显示分页导航栏和查询结果列表,并提供翻页功能。 下面是一个简单的示例代码,演示了如何手写一个基于MySQL数据库的分页件: ```java // Page类 public class Page { private int pageNum; // 当前页码 private int pageSize; // 每页显示数量 private int total; // 总记录数 // 省略getter和setter方法 } // 数据库查询方法 public List<User> getUsers(Page page) { int offset = (page.getPageNum() - 1) * page.getPageSize(); String sql = "SELECT * FROM user LIMIT ?, ?"; return jdbcTemplate.query(sql, new Object[]{offset, page.getPageSize()}, new BeanPropertyRowMapper<>(User.class)); } // 业务层或控制层 public List<User> getUsers(int pageNum, int pageSize) { Page page = new Page(); page.setPageNum(pageNum); page.setPageSize(pageSize); page.setTotal(userDao.countUsers()); // 获取总记录数 return userService.getUsers(page); } // 前端页面 <!-- 分页导航栏 --> <div class="pagination"> <a href="?pageNum=1">首页</a> <a href="?pageNum=${page.pageNum-1}">上一页</a> <a href="?pageNum=${page.pageNum+1}">下一页</a> <a href="?pageNum=${page.totalPage}">尾页</a> </div> <!-- 查询结果列表 --> <table> <thead> <tr> <th>姓名</th> <th>年龄</th> </tr> </thead> <tbody> <c:forEach items="${users}" var="user"> <tr> <td>${user.name}</td> <td>${user.age}</td> </tr> </c:forEach> </tbody> </table> ``` 希望以上示例能帮助到你!如果有任何问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值