Javascript实现的分页函数
所属分类:
网络编程 / JavaScript
阅读数:
759
收藏 0赞 0分享
From: IECN.Net ; Author: 钟钟
/**
* 分页类构造
* 参数 nTotalList: 总条数
* 参数 nPageSize: 每页显示条数
* 参数 nPageNum: 当前页码
* 参数 sPageUrl: 分页链接的URL,页码以[pn]代替,输出时将被替换为实际页码
* 参数 nPageListSize: 页码列表(下拉框)中显示的最多页码条数。该参数可省略,默认100
*/
function Pagination(nTotalList, nPageSize, nPageNum, sPageUrl, nPageListSize) {
this.totalList = nTotalList;
this.pageSize = nPageSize;
this.pageNum = nPageNum;
if (nTotalList == 0)
this.totalPages = 1;
else
this.totalPages = Math.floor((this.totalList-1)/this.pageSize + 1);
this.pageUrl = sPageUrl;
if (arguments[4])
this.pageListSize = nPageListSize;
else
this.pageListSize = 100;
}
/**
* 生成分页,将HTML直接输出
* 无参数
* 无返回值
*/
Pagination.prototype.generate = function() {
var output = "";
output += "<table width=\"98%\" cellspacing=\"1\" cellpadding=\"3\" align=\"center\"><tr><td align=\"right\">";
output += "共 " + this.totalList + " 条 每页 " + this.pageSize + " 条 当前第 ";
output += "<select onchange=\"if(this.value)location.href='" + this.pageUrl + "'.replace(/\\[pn\\]/,";
output += "this.value);\" align=\"absMiddle\" style=\"font:normal 9px Verdana,Arial,宋体;\">";
var firstPage = this.pageNum - Math.floor(this.pageListSize/2);
if (firstPage < 1)
firstPage = 1;
var lastPage = firstPage + this.pageListSize - 1;
if (lastPage > this.totalPages) {
lastPage = this.totalPages;
firstPage = lastPage - this.pageListSize + 1;
if (firstPage < 1)
firstPage = 1;
}
if (firstPage > 1) {
output += "<option value=\"1\">1</option>";
if (firstPage > 2)
output += "<option value=\"\">…</option>";
}
for (var p = firstPage; p <= lastPage; p++) {
output += "<option value=\"" + p + "\"";
if (p == this.pageNum)
output += " selected=\"yes\"";
output += ">" + p + "</option>";
}
if (lastPage < this.totalPages) {
if (lastPage < this.totalPages - 1)
output += "<option value=\"\">…</option>";
output += "<option value=\"" + this.totalPages + "\">" + this.totalPages + "</option>";
}
if (this.pageNum > this.totalPages)
output += "<option value=\"\" selected=\"yes\">页码超出范围</option>";
output += "</select>";
output += "/" + this.totalPages + " 页 ";
if (this.pageNum == 1) {
output += "[首页] ";
output += "[上页] ";
}
else {
output += "<a href=\"" + this.pageUrl.replace(/\[pn\]/, "1") + "\">[首页]</a> ";
output += "<a href=\"" + this.pageUrl.replace(/\[pn\]/, this.pageNum-1) + "\">[上页]</a> ";
}
if (this.pageNum == this.totalPages) {
output += "[下页] ";
output += "[尾页]";
}
else {
output += "<a href=\"" + this.pageUrl.replace(/\[pn\]/, this.pageNum+1) + "\">[下页]</a> ";
output += "<a href=\"" + this.pageUrl.replace(/\[pn\]/, this.totalPages) + "\">[尾页]</a> ";
}
output += "</td></tr></table>";
document.writeln(output);
}
Node.js事件的正确使用方法
这篇文章主要给大家介绍了关于Node.js事件的正确使用方法,文中通过示例代码介绍的非常详细,对大家学习或者使用Node.js具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
收藏 0赞 0分享
微信小程序自定义导航栏实例代码
这篇文章主要给大家介绍了关于微信小程序自定义导航栏的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用微信小程序具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
收藏 0赞 0分享
js字符串处理之绝妙的代码
这篇文章主要介绍了js字符串处理之绝妙的代码,包括字符串去重、将字符放在对象中遍历拼接出字符串、把字符串的奇数位和偶数位分别提取到两个数组中、将两个数组按奇数位和偶数位插入拼接为字符串,有时候需要对字符进行处理的时候可以用得到
收藏 0赞 0分享
vue设计一个倒计时秒杀的组件详解
这篇文章主要介绍了vue设计一个倒计时秒杀的组件,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0赞 0分享
详解服务端预渲染之Nuxt(介绍篇)
这篇文章主要介绍了详解服务端预渲染之Nuxt(介绍篇),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
收藏 0赞 0分享
详解vue中this.$emit()的返回值是什么
这篇文章主要介绍了详解vue中this.$emit()的返回值是什么,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0赞 0分享
vue自定义指令directive的使用方法
这篇文章主要介绍了vue自定义指令directive的使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
收藏 0赞 0分享
查看更多