分页效果图:

表格下面的分页按钮样式是我自己做的一个样式,这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. bzoj1588 [HNOI2002]营业额统计(Treap)

    1588: [HNOI2002]营业额统计 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 11485  Solved: 4062[Submit][Sta ...

  2. Android应用开发学习之画廊视图

    作者:刘昊昱 博客:http://blog.csdn.net/liuhaoyutz 画廊视图Gallery能按水平方向显示一组图片,并可以拖动图片.下面我们来看一个使用画廊视图的例子,其运行效果如下: ...

  3. hdu4549之矩阵快速幂

    M斐波那契数列 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others) Total Su ...

  4. sqlserver使用OpenQuery或OPENROWSET遇到的问题

    OpenQuery,OPENROWSET允许用户在链接服务器上查询.通过这种方法来得到查询的结果集.     1.在创建存储过程中,必须设置           SET   ANSI_NULLS   ...

  5. 设置IIS7文件上传的最大大小 maxAllowedContentLength,maxRequestLength

    当上传一个超过30M的文件时,服务器会重定向至404.13页面,报错如下: HTTP Error 404.13 - Not Found The request filtering module is ...

  6. ExtJS学习-----------Ext.String,ExtJS对javascript中的String的扩展

    关于ExtJS对javascript中的String的扩展,能够參考其帮助文档,文档下载地址:http://download.csdn.net/detail/z1137730824/7748893 以 ...

  7. [CSS3] CSS :target Selector

    The :target selector allows us to interact with a fragment identifier, or hash, in our URL from CSS. ...

  8. 微信支付bug

    1.最基本的操作就是检查各项参数正确2.确保将测试微信号加入测试白名单 3.目录正确:发起授权请求的页面必须是在授权目录下的页面,而不能是存在与子目录中.否则会返回错误,Android返回“Syste ...

  9. 关于Linux的缓存内存 Cache Memory详解<转>

    转自 http://www.ha97.com/4337.html PS:前天有童鞋问我,为啥我的Linux系统没运行多少程序,显示的可用内存这么少?其实Linux与Win的内存管理不同,会尽量缓存内存 ...

  10. servlet 配置到服务器

    最近写了个安卓项目,服务端用的servlet.因为第一次写java项目,写完如何发布不是太清除,于是把这回经理写出来,一来做个记录,二来也给和我同样经历的朋友一点启示. 首先配置你的java主机和你的 ...