局部刷新的js分页插件

补上写好的js分页插件。水平有限,可供参考。另外有好建议的可以在评论里面提出,我再做优化。废话不多说了,代码走起!


(一)splitPage.js分页插件

直接copy就能使用:

/***
 * 功能:局部刷新分页显示表格内容
 * 作者:JML
 * 版本:1.0
 * 备注:自己封装的局部刷新分页插件,主要是想了解一下分页插件是如何运作的
 * 缺陷:水平有限,插件很不灵活,还有两个硬编码块
 * 建议:大家还是下载专门的js分页插件来进行使用吧(本代码可供参考)
*/

/**
 * 帮助文档:
 * 1.结合jQuery.js来进行使用
 * 2.提供了两个方法可供调用
 *  方法一:splitPage(tableID,tableHeadName,tableData,checkboxRow)
 *      参数详解[
 *          tableID:需要用户在jsp页面写一个空的表格并赋予id值
 *          tableHeadName:表头内容(格式如:["图书ID","图书名称","图书价格","入库时间"])
 *          tableData:数据源(后台查到的list集合[可以是json字符串][也可以是json字符串解析过后的对象数组])
 *          checkboxRow:boolean类型([true:表示显示多选框][false:不显示多选框])
 *      ]
 *
 *  方法二:getCheckedBoxs()
 *      返回值详解[
 *          (null):表示用户没有选择任何一条记录
 *          (a):表示用户选择了一条记录
 *          (a,b,c..z):表示用户选择了多条记录
 *      ]
 *      友情提示[
 *          关于用户到底选择了一条还是多条,可以通过 indexOf(",")>0 来进行判断
 *          即:如果返回的字符串包含‘,‘,就表示有选择了多条记录
 *      ]
 * 3.关于硬编码块
 *  硬编码块-:initTableData()
 *      解释[
 *          水平有限,遍历集合数据时,只能按照JavaBean里面的属性顺序遍历
 *          有(不需要显示的字段)和(需要转换格式的字段),需要用户手动在本方法里面添加if块
 *          格式如下:
 *              if(filedName=="该字段名称")
 *              {
 *                  具体操作
 *                  continue;
 *              }
 *      ]
 *  硬编码块二:getBoxValue()
 *      解释[
 *          水平有限,获取用户选择的多选框时,把多选框的值拼成字符串返回
 *          默认是把 该多选框的下一个单元格内容的值 赋给多选框
 *          用户可以根据需求更改此块,格式如下:
 *          obj.parentNode.nextSibling.firstChild.nodeValue
 *         当前对象   父元素    下一个兄弟元素   第一个子元素   节点值
 *      ]
 *
*/

/**
 * [用户可调用]分页方法
*/
function splitPage(tableID,tableHeadName,tableData,checkboxRow)
{
    initPageData(tableID,tableHeadName,tableData,checkboxRow);
}

/**
 * [不可调用]初始化页面方法(默认第一页,每页5条)
*/
function initPageData(tableID,tableHeadName,tableData,checkboxRow)
{
    var page=1;
    var pageSize=5;
    doSplitPage(tableID,tableHeadName,tableData,page,pageSize,checkboxRow);
}

/**
 * [不可调用]真正分页方法
*/
function doSplitPage(tableID,tableHeadName,tableData,page,pageSize,checkboxRow)
{
    var listCount;
    var pageCount;
    if(typeof(tableData)=="string")
    {
        tableData=tableData.replace(/\%/g,"\"");
        tableData=eval("("+tableData+")");
    }
    if(typeof(tableHeadName)=="string")
    {
        tableHeadName=tableHeadName.split(",");
    }
    listCount=tableData.length;
    pageCount=parseInt(listCount/pageSize) + (listCount%pageSize==0?0:1);
    showTableData(tableID,tableHeadName,tableData,listCount,page,pageSize,pageCount,checkboxRow);
}

/**
 * [不可调用]渲染 表格 方法
*/
function showTableData(tableID,tableHeadName,tableData,listCount,page,pageSize,pageCount,checkboxRow)
{
    var colspanCell=tableHeadName.length;
    $("#"+tableID+" tr").remove();
    initTableHead(tableID,tableHeadName,checkboxRow);
    initTableData(tableID,tableData,listCount,page,pageSize,pageCount,checkboxRow);
    initTableFoot(tableID,tableHeadName,tableData,listCount,page,pageSize,pageCount,colspanCell,checkboxRow);
}

/**
 * [不可调用]渲染 表头 方法
*/
function initTableHead(tableID,tableHeadName,checkboxRow)
{
    var initHeadLine="<tr>";
    if(checkboxRow.toString()=="true")
    {
        initHeadLine+=‘<td><input type="checkbox" id="parent" onclick="choiceBoxStatus(this);" /></td>‘;
    }
    for(var i=0;i<tableHeadName.length;i++)
    {
        initHeadLine+="<td>"+tableHeadName[i]+"</td>";
    }
    initHeadLine+="</tr>";
    $("#"+tableID).append(initHeadLine);
}

/**
 * [不可调用]渲染 表格数据 方法
*/
function initTableData(tableID,tableData,listCount,page,pageSize,pageCount,checkboxRow)
{
    var firstLine=parseInt((page-1)*pageSize);
    var lastLine=parseInt((page-1)*pageSize)+parseInt(pageSize);
    if(page==pageCount)
    {
        lastLine=firstLine+(listCount-((pageCount-1)*pageSize));
    }
    for(var i=firstLine;i<lastLine;i++)
    {
        var initDataLine="<tr>";
        if(checkboxRow.toString()=="true")
        {
            initDataLine+=‘<td><input type="checkbox" name="kid" onclick="getBoxValue(this);"/></td>‘;
        }
        for(var filedName in tableData[i]){
            if(filedName=="ctime")
            {
                var ctime=new Date(tableData[i][filedName]);
                var year = ctime.getFullYear();
                var month = ctime.getMonth()+1;//js从0开始取
                var date = ctime.getDate();
                var hour = ctime.getHours();
                var minutes = ctime.getMinutes();
                var second = ctime.getSeconds();
                ctime=year+"年"+month+"月"+date+"日 "+hour+"时"+minutes +"分"+second+"秒";
                initDataLine+="<td>"+ctime+"</td>";
                continue;
            }
            initDataLine+="<td>"+tableData[i][filedName]+"</td>";
        }
        initDataLine+="</tr>";
        $("#"+tableID).append(initDataLine);
    }
}

/**
 * [不可调用]渲染 表格尾行提示 方法
*/
function initTableFoot(tableID,tableHeadName,tableData,listCount,page,pageSize,pageCount,colspanCell,checkboxRow)
{
    tableData=JSON.stringify(tableData).replace(/\"/g,"\%");
    if(checkboxRow.toString()=="true")
    {
        colspanCell=parseInt(colspanCell+1);
    }
    var initFootLine="<tr><td colspan=‘"+colspanCell+"‘ align=‘center‘ id=‘tableFootInfo‘></td></tr>";
    $("#"+tableID).append(initFootLine);
    var footInfoID="tableFootInfo";
    $("#"+footInfoID).append("<select id=‘tableSize‘ onchange=‘changeTableSize(\""+tableID+"\",\""+tableHeadName+"\",\""+tableData+"\",\""+page+"\",\""+pageSize+"\",\""+checkboxRow+"\");‘><option value=‘5‘ "+(pageSize==5?"selected=‘selected‘":"")+">每页5条</option><option value=‘10‘ "+(pageSize==10?"selected=‘selected‘":"")+">每页10条</option><option value=‘15‘ "+(pageSize==15?"selected=‘selected‘":"")+">每页15条</option></select>"+"&nbsp;&nbsp;&nbsp;&nbsp;");
    showFirstInfo(tableID,tableHeadName,tableData,page,pageSize,pageCount,footInfoID,checkboxRow);
    showPrevInfo(tableID,tableHeadName,tableData,page,pageSize,pageCount,footInfoID,checkboxRow);
    showNextInfo(tableID,tableHeadName,tableData,page,pageSize,pageCount,footInfoID,checkboxRow);
    showLastInfo(tableID,tableHeadName,tableData,page,pageSize,pageCount,footInfoID,checkboxRow);
    $("#"+footInfoID).append("&nbsp;&nbsp;&nbsp;&nbsp;"+"当前是"+page+"/"+pageCount+"页");
    $("#"+footInfoID).append("&nbsp;&nbsp;&nbsp;&nbsp;"+"共计"+listCount+"条数据");
}

/**
 * [不可调用]渲染 首页 方法
*/
function showFirstInfo(tableID,tableHeadName,tableData,page,pageSize,pageCount,footInfoID,checkboxRow)
{
    if(page!=1)
    {
        page=1;
        $("#"+footInfoID).append("<a href=‘JavaScript:void(0);‘ onclick=‘doSplitPage(\""+tableID+"\",\""+tableHeadName+"\",\""+tableData+"\",\""+page+"\",\""+pageSize+"\",\""+checkboxRow+"\");‘>首页</a>");
    }else
    {
        $("#"+footInfoID).append("首页");
    }
}

/**
 * [不可调用]渲染 上一页 方法
*/
function showPrevInfo(tableID,tableHeadName,tableData,page,pageSize,pageCount,footInfoID,checkboxRow)
{
    if(page>1)
    {
        page=parseInt(page)-1;
        $("#"+footInfoID).append("<a href=‘JavaScript:void(0);‘ onclick=‘doSplitPage(\""+tableID+"\",\""+tableHeadName+"\",\""+tableData+"\",\""+page+"\",\""+pageSize+"\",\""+checkboxRow+"\");‘>上一页</a>");
    }
    else
    {
        $("#"+footInfoID).append("上一页");
    }
}

/**
 * [不可调用]渲染 下一页 方法
*/
function showNextInfo(tableID,tableHeadName,tableData,page,pageSize,pageCount,footInfoID,checkboxRow)
{
    if(page<pageCount)
    {
        page=parseInt(page)+1;
        $("#"+footInfoID).append("<a href=‘JavaScript:void(0);‘ onclick=‘doSplitPage(\""+tableID+"\",\""+tableHeadName+"\",\""+tableData+"\",\""+page+"\",\""+pageSize+"\",\""+checkboxRow+"\");‘>下一页</a>");
    }
    else
    {
        $("#"+footInfoID).append("下一页");
    }
}

/**
 * [不可调用]渲染 末页 方法
*/
function showLastInfo(tableID,tableHeadName,tableData,page,pageSize,pageCount,footInfoID,checkboxRow)
{
    if(page!=pageCount && pageCount!=0)
    {
        page=pageCount;
        $("#"+footInfoID).append("<a href=‘JavaScript:void(0);‘ onclick=‘doSplitPage(\""+tableID+"\",\""+tableHeadName+"\",\""+tableData+"\",\""+page+"\",\""+pageSize+"\",\""+checkboxRow+"\");‘>末页</a>");
    }
    else
    {
        $("#"+footInfoID).append("末页");
    }
}

/**
 * [不可调用]改变表格记录条数
*/
function changeTableSize(tableID,tableHeadName,tableData,page,pageSize,checkboxRow)
{
    page=1;
    pageSize=$("#tableSize").val();
    doSplitPage(tableID,tableHeadName,tableData,page,pageSize,checkboxRow);
}

/**
 * [不可调用]全选/全不选
*/
function choiceBoxStatus(obj)
{
    var boxs=document.getElementsByName("kid");
    for(var i=0;i<boxs.length;i++)
    {
        boxs[i].checked=obj.checked;
        getBoxValue(boxs[i]);
    }
}

/**
 * [不可调用]给多选框赋值
*/
function getBoxValue(obj)
{
    var boxValue=obj.parentNode.nextSibling.firstChild.nodeValue;
    obj.value=boxValue;
}

/**
 * [用户可调用]获取选择的多选框的id字符串
*/
function getCheckedBoxs()
{
    var boxs=document.getElementsByName("kid");
    var ids="";
    var boxIDS="";
    for(var i=0;i<boxs.length;i++)
    {
        if(boxs[i].checked)
        {
            boxIDS+=boxs[i].value+",";
        }
    }
    ids=boxIDS.substring(0, boxIDS.length-1);
    if(ids.length==0)
    {
        ids=null;
    }
    return ids;
}

/**
 * ---end---
*/

(二)使用帮助

本插件提供了两个方法可被调用

方法一:splitPage(tableID,tableHeadName,tableData,checkboxRow)

核心方法:进行局部刷新分页

方法二:getCheckedBoxs()

辅助方法:返回 用户所选择的记录id 拼成的字符串

splitPage 参数介绍:

参数 备注
tableID 需要用户在jsp页面写一个空的表格并赋予id值
tableHeadName 表头内容(格式如:[“图书ID”,”图书名称”])
tableData 数据源(后台查到的list集合)[可以是json字符串][也可以是json字符串解析过后的对象数组]
checkboxRow boolean类型:[true:表示显示多选框][false:不显示多选框]

getCheckedBoxs 返回值介绍:

返回值 备注
null 表示用户没有选择任何一条记录
a 表示用户选择了一条记录
a,b,c…z 表示用户选择了多条记录

提示:

关于用户到底选择了一条还是多条,可以通过 indexOf(“,”)>0 来进行判断

即:如果返回的字符串包含’,’,就表示有选择了多条记录


(三)使用案例

jsp页面代码:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%@ taglib prefix="format" uri="http://java.sun.com/jsp/jstl/fmt" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>列表</title>

<!-- 调用jQuery.js -->
<script type="text/javascript" src="<%=request.getContextPath()%>/js/jquery-1.9.1.js"></script>
<!-- 调用splitPage.js -->
<script type="text/javascript" src="<%=request.getContextPath()%>/js/splitPage.js"></script>

<!-- 方法块 -->
<script type="text/javascript">

$(document).ready(function(){
    $.ajax({
        type:"post",
        url:"<%=request.getContextPath()%>/doList.action",
        data:{},
        dataType:"json",
        success:function(data)
        {
            var TableID="bookTable";
            var TableHeadName=["图书ID","图书名称","图书价格","入库时间"];
            var TableData=data;
            var CheckboxRow=true;

            splitPage(TableID,TableHeadName,TableData,CheckboxRow);
        }
    });
});

function insert()
{
    location.href="<%=request.getContextPath()%>/toAddPage.action";
}

function update()
{
    var result=getCheckedBoxs();
    if(result==null)
    {
        alert("请选择要修改的语句!");
    }else if(result.indexOf(",")>0)
    {
        alert("您选择了多条语句!");
    }else
    {
        location.href="<%=request.getContextPath()%>/toUpdatePage.action?id="+result;
    }
}

function del()
{
    var result=getCheckedBoxs();
    if(result==null)
    {
        alert("请选择要删除的语句!");
    }else if(result.indexOf(",")>0)
    {
        var pro=confirm("请问您是否要删除您选中的多条记录?");
        if(pro)
        {
            location.href="<%=request.getContextPath()%>/doDelAll.action?id="+result;
        }
    }else
    {
        var pro=confirm("请问您是否要删除该记录?");
        if(pro)
        {
            location.href="<%=request.getContextPath()%>/doDel.action?id="+result;
        }
    }
}
</script>

</head>

<body>
    <div>
        <input type="button" value="添加" onclick="insert();"/>
        <input type="button" value="修改" onclick="update();"/>
        <input type="button" value="删除" onclick="del();"/>
    </div>
    <table border="1" id="bookTable"></table>
</body>
</html>

结束语

光有骤然而至的冲动和百折不饶的顽强精神还不是生活,生活还包括了妥协和忘却。

时间: 2024-11-09 01:28:27

局部刷新的js分页插件的相关文章

Jquery.Page.js 分页插件的使用

1.简单直接贴代码 需要引用以下样式和脚本 <link href="~/Scripts/Page/pager.css" rel="stylesheet" /> <script src="~/Scripts/jQuery-1.8.3.js"></script> <script src="~/Scripts/Page/jquery.pager.js"></script>

js分页插件

//分页插件 function showView(option) {        //参数定义id,页容量,当前页,总数,页总数        var id = option.id,         pageSize = option.pageSize,         currentPage = option.currentPage,         totalCount = option.totalCount,         pageCount = 0;        if (Numbe

JS分页插件-GCPager

1 //IE8及以下引入json2.js,IE8不支持JSON.stringify()方法,基于JQuery,使用前先引入1.x版本的JQuery 2 //服务端返回的格式为{"recordCount":333,"data":.......} 3 $.extend( 4 { 5 GcPager: function (options) { 6 if (!options) return; 7 var ContainerId = options.ContainerId;/

kkpager.js 分页插件

<script src="/static/js/lib/jquery-pages/kkpager.min.js"></script> <script> $(function () { /*分页*/ paging(); }); function paging() { var totalPage = 20; var totalRecords = 12; var pageNo = getParameter('page'); if (!pageNo) { p

jquery.pagination.js分页插件的使用

1.引用jquery.pagination.js <script src="${ctx}/themes/b2b2cv2/doctor/js/message/jquery.pagination.js"></script> 2.发送2次ajax请求,第一次需传入首页和页大小,返回数据得到所有数据的长度: 第二次发送请求传入点击的页码号和页的大小,返回数据得到点击页的数据 参考链接: 1.https://blog.csdn.net/baidu_25343343/art

一个比较轻巧好用的js分页插件,可ajax可url

var pageNav = pageNav || {}; pageNav.fn = null; pageNav.pre = "pre"; pageNav.next = "next"; pageNav.nav = function (a, b) { if (1 >= b)return this.pn = this.p = 1, this.pHtml2(1); b < a && (a = b); var c = ""; 1

MVC如何使用开源分页插件shenniu.pager.js

最近比较忙,前期忙公司手机端接口项目,各种开发+调试+发布现在几乎上线无问题了:虽然公司项目忙不过在期间抽空做了两件个人觉得有意义的事情,一者使用aspnetcore开发了个人线上项目(要说线上其实只能ip访问,没有域名哈哈),其架构组成由:aspnetcore1.0.0+redis+ postgressql+TaskMainForm服务,这个项目在后期会开源出来供大家分享学习,站点地址点这里心声网:一者是目前正在做的后台管理框架一叶子,现目前刚好吧js分页插件shenniu.pager.js写

Bootstrap Paginator 分页插件参数介绍及使用

Bootstrap Paginator是一款基于Bootstrap的js分页插件,功能很丰富,个人觉得这款插件已经无可挑剔了.它提供了一系列的参数用来支持用户的定制,提供了公共的方法可随时获得插件状态的改变,以及事件来监听用户的动作.目前经过测试的浏览器包括: Firefox 5+, Chrome 14+, Safari 5+, Opera 11.6+ and IE 7+. GitHub 官网地址:https://github.com/lyonlai/bootstrap-paginator 参数

jQuery翻页yunm.pager.js,涉及div局部刷新

前端的翻页插件有很多,bootstrap的翻页界面看起来就不错,做起来也易于上手,但应用于项目中的翻页实现还有有几个难点,分别是: 如何封装一个翻页插件,如题中的yunm.pager.js. 涉及到的div局部刷新该如何做. 翻页的总体流程涉及到的知识点很多,这篇文章我们也主要来关注以上两点,其余的内容,请自悟. 一.如何定义局部刷新的div 翻页时,我们一般只会刷新页面中涉及到翻页的父级div,那么该如何定义呢? <form rel="support_deal_page" ta