Nhibernate 分页功能
cs:
public IEnumerable<ArticleView> MyGetAll(int start, int limit, ref int count)
{
try
{
var query = _session.CreateCriteria<Article>();
count = query.List<Article>().Count;
var data = query.SetFirstResult((start - ) * limit)
.SetMaxResults(limit)
.AddOrder(new Order("CreateTime", false))
.List<Article>();
return ArticleMapper.GetArticleView(data);
}
catch (Exception)
{
throw;
}
}
js:
$(function () {
getAllArticle();
getAllLable();
$('#jumbotron').hide();
showTip();
scrollUp();
setTimeout(showTip2, );
});
var myCurrentPage = , myTotalPages = ;
function bootStrapPage() {
var options = {
currentPage: myCurrentPage,
totalPages: myTotalPages,
size: 'small',
itemContainerClass: function (type, page, current) {
return (page === current) ? "active" : "pointer-cursor";
},
itemTexts: function (type, page, current) {
switch (type) {
case "first":
return "First";
case "prev":
return "上一页";
case "next":
return "下一页";
case "last":
return "Last";
case "page":
return page;
default:
return null;
}
},
shouldShowPage: function (type, page, current) {
switch (type) {
case "first":
case "last":
return false;
default:
return true;
}
},
onPageClicked: function (e, originalEvent, type, page) {
myCurrentPage = page;
zwobj.url = Resolve('/Home/GetAllArticle/?currentPage=' + myCurrentPage);
ajaxData();
}
};
$('#example').bootstrapPaginator(options);
} function showTip2() {
if ($('#colspan').hasClass('glyphicon-chevron-up')) {
$('#colspan').removeClass('glyphicon-chevron-up').addClass('glyphicon-chevron-down');
} else {
$('#colspan').removeClass('glyphicon-chevron-down').addClass('glyphicon-chevron-up');
}
$('#jumbotron').animate({ height: 'toggle' }, );
} function showTip() {
$('#colspan').click(function () {
if ($('#colspan').hasClass('glyphicon-chevron-up')) {
$('#colspan').removeClass('glyphicon-chevron-up').addClass('glyphicon-chevron-down');
} else {
$('#colspan').removeClass('glyphicon-chevron-down').addClass('glyphicon-chevron-up');
}
$('#jumbotron').animate({
height: 'toggle'
}, );
});
} function getAllArticle() {
zwobj.url = Resolve('/Home/GetAllArticle/?currentPage=' + myCurrentPage);
zwobj.data = {};
ajaxData();
} function getAllLable() {
zwobj.url = Resolve('/Home/GetAllLable');
zwobj.data = {};
ajaxData();
} function scrollUp() {
$.scrollUp({
scrollName: 'scrollUp', // Element ID
topDistance: '', // Distance from top before showing element (px)
topSpeed: , // Speed back to top (ms)
animation: 'fade', // Fade, slide, none
animationInSpeed: , // Animation in speed (ms)
animationOutSpeed: , // Animation out speed (ms)
scrollText: '', // Text for element
activeOverlay: false // Set CSS color to display scrollUp active point, e.g '#00FFFF'
});
} function ajax_GetAllArticle(data) {
$(".content_list tbody").empty();
var html = "";
var len = data.Data.length;
for (var i = ; i < len; i++) {
html += '<tr><td scope="row"><div class="clearfix">发布于: ' + eval("new " + data.Data[i].CreateTime.split('/')[]).Format("yyyy-MM-dd HH:mm") + '</div>'
+ '<div class="clearfix"><div class="clearfix-left">作者:</div><div class="clearfix-left"> <img src="http://i3.asp.net/avatar/RicardoPeres.jpg?forceidenticon=True&dt=635278383000000000&cdn_id=2013-08-19-003"alt="author"> </div><div class="common-a"><a href="#">' + data.Data[i].UserName + '</a></div></div>'
+ '<div class="clearfix">职称: ' + data.Data[i].UserPostTitle + '</div>'
+ '<div class="clearfix"><div class="clearfix-left">联系:</div><div class="clearfix-left"> <img src="../../Images/qq.png" /> <img src="../../Images/sina.jpg" /> <img src="../../Images/weibo.ico" /></div></div>'
+ '</td><td>'
+ '<h3><a href="#">' + data.Data[i].Title + '</a></h3>'
+ '<div class="td-content">' + data.Data[i].Contents.substr(, ) + '...</div>'
+ '<div class="common-a">Tags:';
var len2 = data.Data[i].Lables.length;
for (var j = ; j < len2; j++) {
html += '<a href="#" rel="tag">' + data.Data[i].Lables[j].Name + '</a> ';
}
html += '</div></td>';
}
$(".content_list tbody").append(html); //总页数
var total = parseInt(data.Other);
myTotalPages = (total / 20) + 1;
bootStrapPage();
} function ajax_GetAllLable(data) {
$(".label-content").empty();
var html = "";
var len = data.Data.length;
for (var i = ; i < len; i++) {
html += '<span class="label label-primary">Primary</span> <span class="label label-success">Success</span>';
}
$(".label-content").append(html);
}
html:
<%@ Page Language="C#" Inherits="System.Web.Mvc.ViewPage<dynamic>" %> <!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="description" content="">
<meta name="author" content="">
<title>优尔博客</title>
<!--Bootstrap css-->
<link rel="shortcut icon" href="../../Scripts/bootstrap-3.1.0/dist/ico/favicon.ico" />
<link href="../../Scripts/bootstrap-3.1.0/dist/css/bootstrap.css" rel="stylesheet"
type="text/css" />
<!--jquery page css-->
<link href="../../Scripts/bootstrap-paginator-master/bootstrap-combined.min.css"
rel="stylesheet" type="text/css" />
<link href="../../Scripts/bootstrap-3.1.0/jumbotron/jumbotron.css" rel="stylesheet"
type="text/css" />
<!--本页面 css-->
<link href="../../Scripts/Lib/Home/Home.css" rel="stylesheet" type="text/css" />
<script src="../../Scripts/jquery/jquery-1.8.3.js" type="text/javascript"></script>
<!--jquery-scrollUp js-->
<script src="../../Scripts/jquery.scrollUp.min.js" type="text/javascript"></script>
<!--bootstrap js-->
<script src="../../Scripts/bootstrap-3.1.0/dist/js/bootstrap.js" type="text/javascript"></script>
<!--jquery page js-->
<script src="../../Scripts/bootstrap-paginator-master/bootstrap-paginator.js"
type="text/javascript"></script>
<script src="../../Scripts/HtmlHelper.js" type="text/javascript"></script>
<script src="../../Scripts/zwjs.js" type="text/javascript"></script>
<script src="../../Scripts/Lib/Home/Home.js" type="text/javascript"></script>
</head>
<body>
<div class="navbar navbar-inverse navbar-fixed-top" role="navigation">
<div class="container">
<div class="navbar-header">
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
<span class="sr-only">Toggle navigation</span> <span class="icon-bar"></span><span
class="icon-bar"></span><span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="#">合肥优尔电子科技有限公司</a>
<div id="colspan" class="glyphicon glyphicon-chevron-down">
</div>
</div>
<div class="navbar-collapse collapse">
<ul class="nav navbar-nav">
<li class="active"><a href="#">主页</a></li>
<li class="dropdown"><a href="#" class="dropdown-toggle" data-toggle="dropdown">博客园
<b class="caret"></b></a>
<ul class="dropdown-menu">
<li><a href="#">推荐博客</a></li>
<li><a href="#">新闻</a></li>
<li><a href="#">专题</a></li>
<li><a href="#">知识库</a></li>
</ul>
</li>
<li class="dropdown"><a href="#" class="dropdown-toggle" data-toggle="dropdown">行业动态
<b class="caret"></b></a>
<ul class="dropdown-menu">
<li><a href="#">华尔街日报</a></li>
<li><a href="#">中文业界资讯站</a></li>
<li><a href="#">软媒</a></li>
</ul>
</li>
<li><a href="#">关于</a></li>
<li><a href="#">联系我</a></li>
</ul>
<div class="navbar-form navbar-right">
<button type="submit" class="btn btn-success">
登 入</button>
</div>
</div>
<!--/.navbar-collapse -->
</div>
</div>
<!-- Main jumbotron for a primary marketing message or call to action -->
<div class="jumbotron" id="jumbotron">
<div class="container" id="container">
<h1>
YouoBlog 1.0</h1>
<p>
这是一个公司内部交流使用的博客系统,它服务于公司内部人员更好的进行团队协作和免除了face-to-face的交流机会, 它的诞生标志着我们迈向了一个新的阶段。</p>
<p>
<a class="btn btn-primary btn-lg" role="button">了解更多 »</a></p>
</div>
</div>
<div class="container">
<div id="container-left">
<div class="alert alert-info">
<span class="glyphicon glyphicon-info-sign"></span> 欢迎提出您在使用中遇到的问题或宝贵建议,感谢您对优尔博客的支持。QQ:1576410833
</div>
<div class="container-blog">
<table width="100%" border="0" cellspacing="0" cellpadding="2" class="content_list"
summary="youo blog">
<tbody>
</tbody>
</table>
<div id="example"></div>
<hr />
<footer>
<p>© Company 2014</p>
</footer>
</div>
</div>
<div id="container-right">
<div class="input-group">
<input type="text" class="form-control">
<span class="input-group-btn">
<button class="btn btn-primary" type="button">
搜索</button>
</span>
</div>
<div class="panel panel-join">
<div class="panel-heading">
<h3 class="panel-title">
<span class="glyphicon glyphicon-bookmark"> 最新新闻</span>
</h3>
</div>
<div class="panel-body">
<ul>
<li>为程序员的爱情点赞</li>
<li>董明珠密会黄章是要干啥?</li>
<li>硅谷风投大亨安德森:科技行业正走出衰退</li>
<li>苹果可考虑的10个投资选项</li>
<li>投资人为啥不投你?</li>
<li>为什么很多互联网公司都在开曼群岛注册?</li>
<li>“八叛逆”之摩尔:摩尔定律提出者</li>
<li>Twitter们的未来是信息重构么?</li>
<li>惠普今春发布Chromebox 外形效仿Mac Mini</li>
<li>亚马逊将新招2500人 股票评级遭UBS下调</li>
</ul>
</div>
</div>
<div class="panel panel-learn">
<div class="panel-heading">
<h3 class="panel-title">
<span class="glyphicon glyphicon-bookmark"> 常用资源</span></h3>
</div>
<div class="panel-body">
<ul>
<li>为程序员的爱情点赞</li>
<li>董明珠密会黄章是要干啥?</li>
<li>硅谷风投大亨安德森:科技行业正走出衰退</li>
<li>苹果可考虑的10个投资选项</li>
<li>投资人为啥不投你?</li>
<li>为什么很多互联网公司都在开曼群岛注册?</li>
<li>“八叛逆”之摩尔:摩尔定律提出者</li>
<li>Twitter们的未来是信息重构么?</li>
<li>惠普今春发布Chromebox 外形效仿Mac Mini</li>
<li>亚马逊将新招2500人 股票评级遭UBS下调</li>
</ul>
</div>
</div>
<div class="panel panel-sign">
<div class="panel-heading">
<h3 class="panel-title">
<span class="glyphicon glyphicon-bookmark"> 热门标签</span></h3>
</div>
<div class="panel-body label-content"> </div>
</div>
<div class="panel panel-code">
<div class="panel-heading">
<h3 class="panel-title">
<span class="glyphicon glyphicon-bookmark"> 相关博客</span></h3>
</div>
<div class="panel-body">
<ul>
<li>为程序员的爱情点赞</li>
<li>董明珠密会黄章是要干啥?</li>
<li>硅谷风投大亨安德森:科技行业正走出衰退</li>
<li>苹果可考虑的10个投资选项</li>
<li>投资人为啥不投你?</li>
<li>为什么很多互联网公司都在开曼群岛注册?</li>
<li>“八叛逆”之摩尔:摩尔定律提出者</li>
<li>Twitter们的未来是信息重构么?</li>
<li>惠普今春发布Chromebox 外形效仿Mac Mini</li>
<li>亚马逊将新招2500人 股票评级遭UBS下调</li>
</ul>
</div>
</div>
</div>
</div>
<!-- /container -->
<a id="scrollUp" href="#top" title="" style="position: fixed; z-index: 2147483647;
display: block;"></a>
</body>
</html>
Controller.cs
[HttpPost]
public JsonResult GetAllArticle(int currentPage)
{
const int totalPages = ;//每页多少数据
ArticleDal articleDal = new ArticleDal(_session);
var count = ;
var data = articleDal.MyGetAll(currentPage, totalPages, ref count);
var zwJson = new ZwJson
{
Data = data,
Other = count.ToString(),
IsSuccess = true,
JsExecuteMethod = "ajax_GetAllArticle"
};
var json= Json(zwJson, JsonRequestBehavior.AllowGet);
return json;
}
Nhibernate 分页功能的更多相关文章
- Nhibernate分页测试续
Nhibernate分页测试续(附源码) 接着上一篇Nhibernate分页测试,最近一直在接触Nhibernate,接触的越多.了解越深,越是感觉他的强大,很多功能都封装的很好,对数据操作是那么的简 ...
- 简单封装分页功能pageView.js
分页是一个很简单,通用的功能.作为一个有经验的前端开发人员,有义务把代码中类似这样公共的基础性的东西抽象出来,一来是改善代码的整体质量,更重要的是为了将来做类似的功能或者类似的项目,能减少不必要的重复 ...
- php对文本文件进行分页功能简单实现
php对文本文件进行分页功能简单实现 <!DOCTYPE> <html> <head> <meta http-equiv="Content-type ...
- Asp.net MVC3表格共用分页功能
在建立的mvc3项目中,在Razor(CSHTML)视图引擎下,数据会在表格中自动的生成,但分页没有好的控件实现,这里我们开发了设计了一个分页的模板,适合于没有数据提交和有数据提交的分页的分页. 第一 ...
- WinForm DataGridView分页功能
WinForm 里面的DataGridView不像WebForm里面的GridView那样有自带的分页功能,需要自己写代码来实现分页,效果如下图: 分页控件 .CS: 1 using System; ...
- Net 分页功能的实现
首先写一个接口 1 2 3 4 5 6 public interface IPagedList { int CurrentPageIndex { get; set; } ...
- 自己封装的JS分页功能[用于搭配后台使用]
* 2016.7.03 修复bug,优化代码逻辑 * 2016.5.25 修复如果找不到目标对象的错误抛出. * 2016.5.11 修复当实际页数(pageNumber)小于生成的页码间隔数时的bu ...
- 一行代码调用实现带字段选取+条件判断+排序+分页功能的增强ORM框架
问题:3行代码 PDF.NET是一个开源的数据开发框架,它的特点是简单.轻量.快速,易上手,而且是一个注释完善的国产开发框架,受到不少朋友的欢迎,也在我们公司的项目中多次使用.但是,PDF.NET比起 ...
- jPList – 实现灵活排序和分页功能的 jQuery 插件
jPList 是一个灵活的 jQuery 插件,可以用于任何 HTML 结构的排序,分页和筛选.它支持的数据源包括:PHP + MySQL,ASP.NET + SQL Server,PHP + SQL ...
随机推荐
- Intent实现页面跳转
Intent实现页面跳转: 1. startActivity(intent) 2. startActivityForResult(intent,requestCode); onActivityResu ...
- SVN理解
先说说什么是branch.按照Subversion的说法,一个branch是某个development line(通常是主线也即trunk)的一个拷贝,见下图: branch存在的意义在于,在不干扰t ...
- 2014年6月5日 深圳 IBM 安全解决方案会议通知
2014年6月5日 深圳 IBM 安全解决方案会议通知 http://gdtesting.com/news.php?id=191 时间: 2014年6月5日 地点: 深圳大中华喜来登 议程: IBM安 ...
- Sqlserver 理解子查询
理解子查询: 理解子查询: 多表连接查询往往也可以用子查询进行替代 子查询本质是嵌套进其他 select update insert Delete 语句的一个被限制的select语句,在子查询中,只有 ...
- Python获取本机的mac,ip,name
Python获取mac 获取计算机名字和ip(内网ip) 指定网卡ip
- 解决自定义BackItem与Pop Gesture冲突的问题
在做项目的时候遇到的这个问题, 一开始项目要求自定义导航栏返回按钮,结果发生了没法手势返回的问题,以为是需要添加拖拽手势呢,结果折腾了一下午没有实现想要的效果.接着一直百度问题,才发现跑偏了,犯了一个 ...
- ReactiveCocoa入门教程——第一部分(转)
作为一个iOS开发者,你写的每一行代码几乎都是在响应某个事件,例如按钮的点击,收到网络消息,属性的变化(通过KVO)或者用户位置的变化(通过CoreLocation).但是这些事件都用不同的方式来处理 ...
- TortoiseSVN本地代码版本控制设置步骤。
1.下载安装TortoiseSVN客户端. 2.在某个盘创建空的文件夹作为项目代码的版本库.在空的文件夹内部右键鼠标TortoiseSVN->Create repository here 3.在 ...
- android 登陆案例_最终版本 sharedpreference
xml 与之前的登陆案例相同 java代码: package com.itheima.login; import java.util.Map; import com.itheima.login.ut ...
- mysql cluster 安装配置方案
mysql cluster (mysql 集群)安装配置方案 一.准备 1.准备服务器 计划建立有5个节点的MySQL CLuster体系,需要用到5台服务器,但是我们做实验时没有这么多机器,可以 ...