public static string GetPageBarStr(int pageIndex, int pageSize, int pageCount, int recordCount)
{
StringBuilder sb = new StringBuilder();
string domStrStart = "";
string domStrEnd = "";
if (pageIndex<1)
{
pageIndex = 1;
}
int start = pageIndex - 2;
if (start <= 2)
{
start = 2;
}
int end = start + 4;
if (end > pageCount)
{
end = pageCount;
start = end - 4;
if (start <= 2)
{
start = 2;
}
}
if (pageCount == 1)
{
start = 1;
}
// 1 ... 3 4 5 6 7 ... 12
if (start > 2)
{
domStrStart = "<span>...</span>";
}
if (pageCount - 1 > end)
{
domStrEnd = "<span>...</span>";
}
for (int i = start; i <= end; i++)
{
if (pageIndex != i)
{
sb.Append("<a href='javascript:void(0)' onclick='pageBarGo(" + (i) + ")'>" + i + "</a>");
}
else
{
sb.Append("<span>" + i + "</span>");
}
}
StringBuilder sb2 = new StringBuilder();
if (pageIndex == 1)
{
sb2.Append("<div class='pageBarDiv'><span>上一页</span>");
}
else
{
sb2.Append("<div class='pageBarDiv'><a href='javascript:void(0)' onclick='pageBarGo(" + (pageIndex - 1) + ")'>上一页</a>");
}
if (start != 1)
{
if (pageIndex != 1)
{
sb2.Append("<a href='javascript:void(0)' onclick='pageBarGo(1)'>" + 1 + "</a>" + domStrStart);
}
else
{
sb2.Append("<span>" + 1 + "</span>" + domStrStart);
}
}
sb2.Append(sb.ToString());
if (end != pageCount)
{
if (pageIndex != pageCount && pageCount!=0)
{
sb2.Append(domStrEnd + "<a href='javascript:void(0)' onclick='pageBarGo(" + (pageCount) + ")'>" + pageCount + "</a>");
}
else
{
sb.Append(domStrEnd + "<span>" + pageCount + "</span>");
}
}
if (pageIndex == pageCount || pageCount == 0)
{
sb2.Append("<span>下一页</span>");
}
else
{
sb2.Append("<a href='javascript:void(0)' onclick='pageBarGo(" + (pageIndex + 1) + ")'>下一页</a>");
}
sb2.Append("共<span class='redspan'>" + recordCount + "</span>条数据,每页显示<input type='text' value='" + pageSize + "' id='pageBar_pageSize'/>条 转到<input type='text' value='" + pageIndex + "' id='pageBar_skip'/><input type='button' value='确定' onclick='pageBarSkip()'/></div><style>.pageBarDiv a {color:#915833; margin-right:5px;} .pageBarDiv span{ margin-right:5px;color:#444444;} .pageBarDiv input[type='text']{width:30px;color:#444444;} .pageBarDiv .redspan{margin-right:3px; margin-left:3px;color:red;} .pageBarDiv button{text-align:center;padding-left:3px;padding-right:3px;color:white;border:none;border-radius:2px;}</style>");
return sb2.ToString();
}
<script>
function pageBarGo(pageIndex) {
ajaxGetData(pageIndex);
}
function pageBarSkip() {
ajaxGetData();
}
function ajaxGetData(pageIndex) {
var pageSize = $("#pageBar_pageSize").val();
var pageSkip = $("#pageBar_skip").val();
if (pageIndex==null) {
pageIndex = pageSkip;
}
if (checkPageBarData(pageSize, pageSkip))
{
var data = $("#f1").serialize() + "action=ajaxGetData&pageIndex=" + pageIndex + "&pageSize=" + pageSize;
alert(data);
$.ajax({
url: "/system/DictAjax",
type: "post",
data: data ,
success: function (response) {
if (response.indexOf("~fuck~")>=0) {
var da = response.split("~fuck~");
if (da[1]=="ok") {
$(".layui-table").find("tr:gt(0)").remove();
$(".layui-table").append(da[2]);
}
else {
layer.msg(da[1]);
}
}
else {
window.top.location.href = "/login/manage";
}
}
});
}
}
function checkPageBarData(pageSize, pageSkip) {
if (isNaN(pageSize) ) {
layer.msg("每页显示数量需是0-50的整数。");
return false;
}
if (isNaN(pageSkip)) {
layer.msg("跳到的页数需是正整数。");
return false;
}
var ps = parseInt(pageSize);
if ( ps<= 0 || ps>50) {
layer.msg("每页显示数量需是0-50的整数。");
return false;
}
var pk = parseInt(pageSkip);
if (pk<=0) {
layer.msg("跳到的页数需是正整数。");
return false;
}
return true;
}
</script>
- 【第四篇】ASP.NET MVC快速入门之完整示例(MVC5+EF6)
目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...
- Bootstrap Metronic 学习记录(二)菜单栏
1.简介 1) .环境配置 2) .提取页面 2).动态生成菜单(无限级别树) 2.系统环境配置 项目需要程序数据支撑,这里选择MVC5.0+EF6.0[SQLSERVER](不对MVC架构和SQ ...
- 自定义分页控件PageList
using System; using System.Collections; using System.Collections.Generic; using System.Linq; using S ...
- jqGrid配置属性说明
Property Type Description Default1) ajaxGridOptions object This option allows to set global ajax set ...
- extjs后自己写了一些见不得人的脚本
<html> <head> <title> 配置管理器 </title> <style type="text/css"> ...
- 数据绑定控件之Repeater
引言 前几篇的文章在说AJAX的内容,利用AJAX技术能够开发出高效运行的网站应用程序,不过在进行B/S项目开发时只拥有AJAX技术是远远不够的,踏入到B/S要学的东西会更多,但相较C/S的复杂逻辑结 ...
- C#编码规范 转 http://www.cnblogs.com/wulinfeng/archive/2012/08/31/2664720.html
C#编码规范 1 规范目的 ……………………………………………………… 3 2 适用范围 ……………………………………………………… 3 3 代码注释 ………………………………………………… ...
- 【PHP】分页条函数封装
这两天在学习PHP 想做一个前端后台都包含的网站 看了一些视频发现大牛们都是将封装起来实现代码的重用性 本人技拙也写了个分页条函数的封装 分页条在用PHP网站开发中十分常用 通过封装代码来提高网站开发 ...
- jqGrid属性中文详细说明 (转)
jqGrid的属性很多,其实很大部分的属性,使用其默认值就可以了.但是详细了解一下属性的含义以及作用,对我们定制自己的grid是有帮助的. 以下内容描述格式是:属性名称 参数值类型 描述内容(可 ...
随机推荐
- C# 正则表达式及常用正则表达式
元字符 描述 .点 匹配任何单个字符.例如正则表达式r.t匹配这些字符串:rat.rut.r t,但是不匹配root. $ 匹配行结束符.例如正则表达式weasel$ 能够匹配字符串"He' ...
- 将ubuntu12.04中,gcc4.6/g++4.6版本降低到gcc4.4/g++4.4.
降低Ubuntu中gcc和g++的版本 ubuntu 12.04 中带的gcc/g++都是4.6,将其降到4.4. 操作步骤如下: 一.降低gcc版本 1. $sudo apt-get install ...
- 《第一行代码--Android》阅读笔记之界面设计
1.单位dp.dip.sp.pt.px.in.mm 这里引用StackOverFlow上的一个解答: px is one pixel. sp is scale-independent pixels. ...
- WPF: 读取XPS文件或将word、txt文件转化为XPS文件
读取XPS格式文件或将doc,txt文件转化为XPS文件,效果图如下: 1.XAML页面代码: <Window x:Class="WpfWord.MainWindow" xm ...
- PHP-PCRE正则表达式函数
PCRE正则表达式函数 PCRE字符类 \\b 词边界 \\d 匹配任意数字 \\s 匹配任意空白,如TAB制表符或空格 \\t 匹配一个TAB ...
- LtUpload上传组件
<?php/** * The Upload class * @author Alex Lee <iuyes@qq.com> * @license http://opensource. ...
- 菜鸟的js学习笔记
学的越多感觉不会的越多.php+mysql学了点皮毛.知道搞web的是要会js的于是开始结合公司的项目开始学习js之旅(http://www.w3school.com.cn/b.asp) $(docu ...
- android中常用菜单(menu)的基本知识
(一)选项菜单 1.简单的创建菜单: @Override public boolean onCreateOptionsMenu(Menu menu) { super.onCreateOptionsMe ...
- Mongodb 3.0 创建用户
MongoDB 3.0 安全权限访问控制,在添加用户上面3.0版本和之前的版本有很大的区别,这里就说明下3.0的添加用户的方法. 创建第一个用户(该用户需要有grant权限,即:账号管理的授权权限) ...
- python的http请求应用--每日签到
写点python吧,python其实是个很好用的工具,作为浇水语言,跟其他语言联系也很紧密,想用什么包直接import,导入ctypes调用底层函数库,导入web相关的包可以轻松写爬虫,今天我们写的跟 ...