分页效果图:

表格下面的分页按钮样式是我自己做的一个样式,这4个按钮都是用同一张图片:这张图片是用ps做的。

接下来我们说一下怎么去做这个样式

第一css代码:

 ._HomePage,._PreviousPage,._NextPage,._TrailerPage{ width:20px; height:20px; background:url(../images/paging.gif) no-repeat; border:none; display:block;}
._HomePage:hover{ opacity:0.7;filter : alpha(opacity:70);}
._PreviousPage:hover{ opacity:0.7;filter : alpha(opacity:70);}
._NextPage:hover{ opacity:0.7;filter : alpha(opacity:70);}
._TrailerPage:hover{ opacity:0.7;filter : alpha(opacity:70);}
._HomePage{ background-position: -7px -4px;}
._PreviousPage{ background-position: -33px -4px;}
._NextPage{ background-position: -62px -4px;}
._TrailerPage{ background-position: -88px -4px;}
._Skip{ width:30px;border:none; background:#f4f4f4;border:#95b8e7 solid 1px;}
._PageSize{ border:none; background:#f4f4f4; border:#95b8e7 solid 1px;}
._Totals{ color:#00F;}

第二html代码:

 <div class="_Paging" id="_Paging">
<center>
<table class="_Layout">
<tr>
<td id="_Shop"></td>
<td><select id="RowCount" title="显示行数" onchange="ClickSelect()" >
<option value="10">10</option>
<option value="20" selected="selected">20</option>
<option value="30">30</option>
<option value="40">40</option>
<option value="50">50</option>
<option value="60">60</option>
<option value="70">70</option>
<option value="80">80</option>
<option value="90">90</option>
<option value="100">100</option>
</select>
</td>
<td>|</td>
<td><a href="javascript:;" class="_HomePage" title="首页" onclick="ShouYe()"></a></td>
<td><a href="javascript:;" class="_PreviousPage" title="上一页" onclick="ShangYiYe()"></a></td>
<td><input class="_Skip" id="txtTiaoZhuan" title="回车跳转" onkeypress="TiaoZhuan(event)" onkeyup="value=value.replace(/[^\d]/g,'')
"onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^\d]/g,''))" /></td>
<td>/<label id="lblZongYeShu"></label></td>
<td><a href="javascript:;" class="_NextPage" title="下一页" onclick="XiaYiYe()"></a></td>
<td><a href="javascript:;" class="_TrailerPage" title="尾页" onclick="WeiYe()"></a></td>
<td>|</td>
<td>
总记录数:<label class = "_Totals" id="lblZongJiLuShu"></label>条
</td>
</tr>
</table>
</center>
</div>
</div>

好啦,我们的样式已经做好啦!

分页的样式可以自己做啊,就算是用按钮代替也是可以的。

接下来我们去看看控制器的代码怎么写:

 /// <summary>
/// 查询与分页(如果是只只执行分页,只需PageSize和CurPage这两个参数就够了)
/// </summary>
/// <param name="strMoHu">模糊查询条件</param>
/// <param name="PageSize">页大小</param>
/// <param name="CurPage">页码</param>
/// <param name="intMenDianID">门店ID</param>
/// <returns></returns>
public ActionResult YuanGong_Load_MoHuChaXun(string strMoHu, int PageSize, int CurPage, int intMenDianID)
{
var dtYuanGongDanAn = (from tbYuanGong in myMdl.sys_YuanGong
join tbMenDian in myMdl.sys_MenDian on tbYuanGong.MenDianID equals tbMenDian.MenDianID
join tbYuanGongZhuangTai in myMdl.sys_ShuXingMingXi on tbYuanGong.YuanGongZhuangTaiID equals tbYuanGongZhuangTai.ShuXingMingXiID
where tbYuanGong.YouXiaoFou == true && tbYuanGong.MenDianID == intMenDianID && (tbYuanGong.YuanGongBianHao.Contains(strMoHu) || tbYuanGong.YuanGongXingMing.Contains(strMoHu) || tbYuanGong.XingBie.Contains(strMoHu) || tbMenDian.GongZuoZhanMingCheng.Contains(strMoHu) || tbYuanGongZhuangTai.ShuXingMingXiMingCheng.Contains(strMoHu))
orderby tbYuanGong.YuanGongID descending
select new
{
tbYuanGong.YuanGongID,
tbYuanGong.MenDianID,
tbYuanGong.YuanGongBianHao,
tbYuanGong.YuanGongXingMing,
tbYuanGong.XingBie,
tbYuanGong.YiDongShouJi,
tbYuanGong.JiaTingDianHua,
tbYuanGong.DiXin,
tbMenDian.GongZuoZhanMingCheng,
tbYuanGongZhuangTai.ShuXingMingXiID,
tbYuanGongZhuangTai.ShuXingMingXiMingCheng,
tbYuanGong.GengXinShiJian,
tbYuanGong.YouXiaoFou
}).AsEnumerable().Select((n, index) => new
{
YuanGongID = n.YuanGongID,
MenDianID = n.MenDianID,
YuanGongBianMa = n.YuanGongBianHao != null ? n.YuanGongBianHao.Trim() : "",
YuanGongXingMing = n.YuanGongXingMing != null ? n.YuanGongXingMing.Trim() : "",
XingBie = n.XingBie != null ? n.XingBie.Trim() : "",
YiDongShouJi = n.YiDongShouJi != null ? n.YiDongShouJi.Trim() : "",
JiaTingDianHua = n.JiaTingDianHua != null ? n.JiaTingDianHua.Trim() : "",
GongZi = n.DiXin != null ? n.DiXin.Trim() : "",
GongZuoDianPu = n.GongZuoZhanMingCheng != null ? n.GongZuoZhanMingCheng.Trim() : "",
YuanGongZhuangTaiID = n.ShuXingMingXiID,
YuanGongZhuangTai = n.ShuXingMingXiMingCheng != null ? n.ShuXingMingXiMingCheng.Trim() : "",
GengXingShiJian = n.GengXinShiJian != null ? n.GengXinShiJian.Value.ToString("yyyy-MM-dd HH:mm:ss") : null,
YouXiaoFou = n.YouXiaoFou,
order = index +
});
int ZongJiLuShu = dtYuanGongDanAn.Count();
if (CurPage > )//在分页前加条件判断
{ //Take是从序列的开头返回指定数量的连续元素,也就是说()里面放的数是多少就返回多少条数据
//Skip是跳过序列中指定的元素,返回剩余的,也就是说()里面放的数是多少,它就跳过多少
dtYuanGongDanAn = dtYuanGongDanAn.Take(PageSize * CurPage).Skip(PageSize * (CurPage - ));//进行分页
}
var jsonMap = new Dictionary<string, object>();//实例化容器
jsonMap.Add("total", ZongJiLuShu);//返回一共存在多少行数据
jsonMap.Add("rows", dtYuanGongDanAn);//返回分页数据
return Json(jsonMap, JsonRequestBehavior.AllowGet);
}

说白了分页就一句代码:

 //Take是从序列的开头返回指定数量的连续元素,也就是说()里面放的数是多少就返回多少条数据
//Skip是跳过序列中指定的元素,返回剩余的,也就是说()里面放的数是多少,它就跳过多少
dtYuanGongDanAn = dtYuanGongDanAn.Take(PageSize * CurPage).Skip(PageSize * (CurPage - ));//进行分页

我们再来看看刚刚写的那些控件要触发什么方法:

第一我们先要定义一个变量,这个变量表示的就是页码:

var CurPage = 1;

第二我们看看查询的方法怎么写:

  function ChaXun() {
$.getJSON("/JiChuZiLiao/YuanGong_Load_MoHuChaXun?strMoHu=" + $('#txtChaXunNeiRong').val()
+ "&" + "PageSize=" + document.getElementById('RowCount').value//获取一页显示多少行
+ "&" + "CurPage=" + CurPage
+ "&" + "intMenDianID=" + MenDianID,
function (data) {
$("#lblZongYeShu").html(function () {
if (data["rows"].length == 0) {
CurPage = 0;
$('#lblZongJiLuShu').html(0);
return 0;
}
else {
$('#lblZongJiLuShu').html(data["total"]);
return Math.ceil(data["total"] / document.getElementById('RowCount').value);
}
});
$('#txtTiaoZhuan').val(CurPage);
$('#tbYuanGongDanAn').datagrid('loadData', data);
}); }

接下来就是分页功能的代码了:

  //下一页
function XiaYiYe() {
if ($("#lblZongYeShu").html() <=CurPage) {
alert("已到最后一页");
return;
}
CurPage++;
ChaXun();
}
//上一页
function ShangYiYe() {
if (1 >= CurPage) {
alert("已到第一页");
return;
}
CurPage--;
ChaXun();
}
//首页
function ShouYe() {
if(CurPage == 1){
alert("当前页已是首页");return;
}
CurPage = 1;
ChaXun();
}
//尾页
function WeiYe() {
if (CurPage == $("#lblZongYeShu").html()){
alert("当前页已是尾页");return;
}
CurPage = $("#lblZongYeShu").html();
ChaXun();
}
//跳转
function TiaoZhuan() {
if(event.keyCode != 13){return;}
if ($("#txtTiaoZhuan").val() == "") {
alert("请输入您要跳转的页数"); return;
}
if (Number($.trim($("#txtTiaoZhuan").val())) > Number($.trim($("#lblZongYeShu").html()))) {
alert("您输入的页数大于当前总页数");
$("#txtTiaoZhuan").val('');
return;
}
if (Number($.trim($("#txtTiaoZhuan").val())) <= 0) {
alert("您输入的页数应大于零");
$("#txtTiaoZhuan").val('') ;
return;
}
CurPage = $("#txtTiaoZhuan").val();
ChaXun();
}
function ClickSelect(){
CurPage=1;
ChaXun();
}

好啦!分页就到此结束啦!

MVC linq语法分页的更多相关文章

  1. Linq语法详细

    闲言碎语 近期比较忙,但还是想写点什么,就分享一些基础的知识给大家看吧,希望能帮助一些linq新手,如果有其它疑问,可以进右上角群,进行交流探讨,谢谢. 开门见山 读这篇文章之前,我先说下,每一种搜索 ...

  2. Linq语法详细(转)

    原文地址:http://www.cnblogs.com/knowledgesea/p/3897665.html 开门见山 读这篇文章之前,我先说下,每一种搜索结果集,我都以三种方式变现出来,为啦更好的 ...

  3. Linq语法

    希望能帮助一些linq新手. 开门见山 读这篇文章之前,我先说下,每一种搜索结果集,我都以三种方式变现出来,为啦更好的理解,希望不要嫌我啰嗦. 1.简单的linq语法 //1 var ss = fro ...

  4. ASP.NET MVC利用PagedList分页(二)PagedList+Ajax+JsRender

    (原文) 昨天在ASP.NET MVC利用PagedList分页(一)的 最后一节提到,一个好的用户体验绝对不可能是点击下一页后刷新页面,所以今天来说说利用Ajax+PagedList实现无刷新(个人 ...

  5. Lamda和Linq语法对比详细

    本人转载:http://www.cnblogs.com/knowledgesea/p/3897665.html 闲言碎语 近期比较忙,但还是想写点什么,就分享一些基础的知识给大家看吧,希望能帮助一些l ...

  6. Linq 语法举例

    1.简单的linq语法 //1 var ss = from r in db.Am_recProScheme select r; //2 var ss1 = db.Am_recProScheme; // ...

  7. Linq语法常见普通语法

    闲言碎语 近期比较忙,但还是想写点什么,就分享一些基础的知识给大家看吧,希望能帮助一些linq新手,如果有其它疑问,可以进右上角群,进行交流探讨,谢谢. 开门见山 读这篇文章之前,我先说下,每一种搜索 ...

  8. C# LINQ语法详解

    1.简单的linq语法 var ss = from r in db.Am_recProScheme select r; var ss1 = db.Am_recProScheme; string sss ...

  9. LINQ语法类似于SQL的语法

    LINQ语法类似于SQL的语法如下, Models.BookStoreEntities 是从添加新建项中的数据--->ADO.NET实体数据模型--->从数据库生成--->使用5.0 ...

随机推荐

  1. apt局域网源搭建

    1, 准备Packages.gz

  2. shell timeout

    写脚本的时候,经常需要用到超时控制.看<shell专家编程>时看到一个好例:修改了一下, 1.超过timeout时间还没执行完,则kill进程,发邮件告警: set-xmailSend() ...

  3. ConcurrentHashMap 原理分析

    1 为什么有ConcurrentHashMap hashmap是非线程安全的,hashtable是线程安全的,但是所有的写和读方法都有synchronized,所以同一时间只有一个线程可以持有对象,多 ...

  4. pull解析和sax解析的差别

    假设在一个XML文档中我们仅仅须要前面一部分数据.可是使用SAX方式或DOM方式会对整个文档进行解析,虽然XML文档中后面的大部分数据我们事实上都不须要解析.因此这样实际上就浪费了处理资源. 使用PU ...

  5. C/C++ Linux 程序员必须了解的 10 个工具

    1. 基本命令http://mally.stanford.edu/~sr/computing/basic-unix.htmlhttp://pangea.stanford.edu/computing/u ...

  6. php include 与 require 起底[转]

    转自 http://www.guangla.com/post/2014-01-24/40060857811 起因: 一朋友面试被问到,php的include和require的区别,这个可能是面试中出现 ...

  7. Android的GridView和Gallery结合Demo

    Android的GridView和Gallery结合Demo Demo介绍:首页是一个GridView加载图片,竖屏时显示3列图片,横屏时显示4列图片;并且对图片进行大小限制和加灰色边框处理. 点击某 ...

  8. carousel

    <!DOCTYPE html> <html lang="en" ng-app="mainApp"> <head> <m ...

  9. (转)ThinkPHP3.0 使用分组后路径访问无效的解决方法!

    注意,清除Runtime,就是清除缓存,很重要,妹的,调试了一下午,总是加上Home目录分组就找不到页面,直接放到action下就行,原来是缓存搞得鬼,另外要在入口文件开启‘APP_DEBUG’ 在T ...

  10. PHP magic_quotes_gpc的详细使用方法

    工作中遇到的代码 if (ini_get('magic_quotes_gpc')) { function stripslashesRecursive(array $array){ foreach ($ ...