JS实现前端分页

news/2024/7/19 13:28:20 标签: JS, HTML

一、HTML部分

<!doctype html>
<html>
<head>
	<meta charset='utf-8'>
    <script src="js/jquery.js"></script>
	<style type="text/css">
		a{text-decoration: none;}
		table {border-collapse:collapse;width: 100%;font-size: 14px;}
		th{background-color: #ddd;}
		table, td, th {border:1px solid #e7e8ec;}
		th,tr{height: 40px;}
		td {text-align: center;}
		tr:hover{background-color: #f9f4f3;}
		.barcon {width: 1000px;margin: 0 auto;text-align: center;}
		.barcon2 {float: right;}
		.barcon2 ul {margin: 20px 0;padding-left: 0;list-style: none;text-align: center;}
		.barcon2 li {display: inline;}
		.barcon2 a {font-size: 16px;font-weight: normal;display: inline-block;padding: 5px;padding-top: 0;color: black;border: 1px solid #ddd;background-color: #fff;}
		.barcon2 a:hover{background-color: #eee;}
		.ban {opacity: .4;}
	</style>
</head>
<body>
<table width="950" cellpadding="0" cellspacing="0" class="table2" align="center">
	<thead>
	<tr align="center">
		<th width="150" height="33" class="td2">序号</th>
		<th width="300" class="td2">用户名</th>
		<th width="250" class="td2">权限</th>
		<th width="250" class="td2">操作</th>
	</tr>
	</thead>
	<tbody id="myTable">
	<tr align="center">
		<td class="td2" height="33" width="150">1</td>
		<td class="td2" >admin</td>
		<td class="td2" >管理员</td>
		<td class="td2" ><a href="###">修改</a></td>
	</tr>
	</tbody>
</table>
<div id="barcon" class="barcon" >
	<div id="barcon2" class="barcon2">
		<ul>
			<li><a href="###" id="prePage">上一页</a></li>
			<li id="barcon1"></li>
			<li><a href="###" id="nextPage">下一页</a></li>
			<li><input type="text" id="num" size="2" oninput="value=value.replace(/[^\d]/g,'')"></li>
			<li><a href="###" id="jumpPage" onclick="jumpPage()">跳转</a></li>
		</ul>
	</div>
</div>
</body>
</html>

二、JS逻辑

<script>
     // 初始化数据
    function dynamicAddUser(num){
        for(var i=1;i<=num;i++)
        {
            var trNode=document.createElement("tr");
            $(trNode).attr("align","center");
            //序号
            var tdNodeNum=document.createElement("td");
            $(tdNodeNum).html(i+1);
            tdNodeNum.style.width = "150px";
            tdNodeNum.style.height = "33px";
            tdNodeNum.className = "td2";
            //用户名
            var tdNodeName=document.createElement("td");
            $(tdNodeName).html("lzj"+i);
            tdNodeName.style.width = "300px";
            tdNodeName.className = "td2";
            //权限
            var tdNodePri=document.createElement("td");
            tdNodePri.style.width = "250px";
            tdNodePri.className = "td2";
            var priText=document.createElement("span");
            $(priText).css({"display":"inline-block","text-align":"center"});
            $(priText).text("普通用户");
            tdNodePri.appendChild(priText);
            //操作
            var tdNodeOper = document.createElement("td");
            tdNodeOper.style.width = "170px";
            tdNodeOper.className = "td2";
            var editA = document.createElement("a");
            $(editA).attr("href", "###").text("编辑");
            $(editA).css({ display: "inline-block" });
            tdNodeOper.appendChild(editA);

            trNode.appendChild(tdNodeNum);
            trNode.appendChild(tdNodeName);
            trNode.appendChild(tdNodePri);
            trNode.appendChild(tdNodeOper);
            $("#myTable")[0].appendChild(trNode);
        }
    }
    $(function(){
        dynamicAddUser(80);
        goPage(1,10);
    })

    /**
     * 分页函数
     * pno--页数
     * psize--每页显示记录数
     * 分页部分是从真实数据行开始,因而存在加减某个常数,以确定真正的记录数
     * 纯js分页实质是数据行全部加载,通过是否显示属性完成分页功能
     **/
    var pageSize=10;//每页显示行数
    var currentPage_=1;//当前页全局变量,用于跳转时判断是否在相同页,在就不跳,否则跳转。
    var totalPage;//总页数
    function goPage(pno,psize){
        var itable = document.getElementById("myTable");
        var num = itable.rows.length;//表格所有行数(所有记录数)

        pageSize = psize;//每页显示行数
        //总共分几页
        if(num/pageSize > parseInt(num/pageSize)){
            totalPage=parseInt(num/pageSize)+1;
        }else{
            totalPage=parseInt(num/pageSize);
        }
        var currentPage = pno;//当前页数
        currentPage_=currentPage;
        var startRow = (currentPage - 1) * pageSize+1;
        var endRow = currentPage * pageSize;
        endRow = (endRow > num)? num : endRow;

        $("#myTable tr").hide();
        for(var i=startRow-1;i<endRow;i++) {
            $("#myTable tr").eq(i).show();
        }

        var tempStr = currentPage+"/"+totalPage;
        document.getElementById("barcon1").innerHTML = tempStr;

        if(currentPage>1){
            $("#firstPage").on("click",function(){
                goPage(1,psize);
            }).removeClass("ban");
            $("#prePage").on("click",function(){
                goPage(currentPage-1,psize);
            }).removeClass("ban");
        }else{
            $("#firstPage").off("click").addClass("ban");
            $("#prePage").off("click").addClass("ban");
        }

        if(currentPage<totalPage){
            $("#nextPage").on("click",function(){
                goPage(currentPage+1,psize);
            }).removeClass("ban")
            $("#lastPage").on("click",function(){
                goPage(totalPage,psize);
            }).removeClass("ban")
        }else{
            $("#nextPage").off("click").addClass("ban");
            $("#lastPage").off("click").addClass("ban");
        }
    }

    function jumpPage() {
        var num=parseInt($("#num").val());
        if(num != currentPage_ && !isNaN(num) && num <= totalPage && num > 0) {
            goPage(num,pageSize);
        }
    }
</script>

效果如图:


http://www.niftyadmin.cn/n/857097.html

相关文章

tab在C语言中的用法,VS下tab control使用方法(非常实用)

1. 在Visual Studio 2005中&#xff0c;新建一个项目&#xff0c;选择MFC应用程序, 取名MyTab, 选择Dialog based(基于对话框), 然后Finish.2. 删除对话框上默认添加的三个控件. 添加Tab Control控件&#xff0c;右键选择“属性”&#xff0c;并设置ID为IDC_TABMAIN。调速尺寸使…

局域网oracle 速度慢,[转帖]局域网中其他用户感觉上网速度慢、网速卡

【故障现象】局域网内有人使用BT、迅雷、电驴、电骡等P2P下载工具进行下载&#xff0c;造成局域网中其他用户感觉上网速度慢、网速卡。【故障原因】当局域网内某台主机使用P2P进行下载时&#xff0c;P2P软件会占用局域网到互联网出口的大量的带宽&#xff0c;导致其他用户网速慢…

mongodb 数组查询 php,mongoDB 多重数组查询的实例介绍

这篇文章主要介绍了mongoDB 多重数组查询(AngularJS绑定显示 nodejs),需要的朋友可以参考下核心代码&#xff1a;js代码var Lesson Schema({lessonName: String,intr: String,creTime: Date,sort: String, //分类imgUrl: String, //封面地址price: Number,teacher: String,//教…

c语言求栈长度程序,数据结构C语言实现之顺序栈

#include #include //定义函数结果状态码#define OK 1#define ERROR 0#define TRUE 1#define FALSE 0//宏定义栈的空间大小#define STACKSIZE 20//定义数据类型typedef int ElemType ;//定义程序返回状态类型typedef int State;//顺序栈存储结构struct _SqStack{ElemType data[…

echarts柱状统计图

目录 一、简单的echarts柱状统计图 二、柱状图和折线图混搭 三、一个项目里同时用不同版本的echarts画图 一、简单的echarts柱状统计图 1、首先映入echarts所需的依赖包&#xff1a;echarts.js和echarts.min.js&#xff0c;以及jQuery.js&#xff1b; echarts官网下载:ht…

JS实现图片自动播放

一、JS实现图片自动播放 1、先看效果图 2、完整代码 <!DOCTYPE html> <html> <head><style>/* 定义样式 */body{margin: 5% 30%;}.bannerimage{width:700px;height:400px;float:left;background-size:100% 100%;color:#fff;box-shadow: 0 0 12px 2px…

matlab计算奇异值和正交矩阵,奇异值、奇异矩阵、SVD分解、正交矩阵

奇异值&#xff1a;奇异值分解法是线性代数中一种重要的矩阵分解法&#xff0c;在信号处理、统计学等领域有重要应用。定义&#xff1a;设A为m*n阶矩阵&#xff0c;A表示A的转置矩阵&#xff0c;A*A的n个特征值的非负平方根叫作A的奇异值。记为σi(A)。如果把A‘*A的特征值记为…

使用My97DatePicker封装一个双选日期组件

由于项目中使用My97DatePicker作为日期控件&#xff0c;额外不用其它日期组件。但是项目需要用到双选日期&#xff0c;一方面放两个空间有限&#xff0c;另一方面看起也不太美观&#xff0c;所以就简单的自己封装一个。 一、准备工作 My97DatePicker下载&#xff1a;http://ww…