Pager分页
分页组件:
/// <summary>
/// 分页组件
/// </summary>
public class PagerHelper
{
/// <summary>
/// 分页组件
/// </summary>
/// <param name="urlFmt">url格式: newsIndex_{pagenum}.shtml </param>
/// <param name="totalsize">总条数</param>
/// <param name="pagesize">每页条数</param>
/// <param name="currentPage">当前页数</param>
/// <returns>分页下标</returns>
public static RawString Pager(string urlFmt, long totalsize, long pagesize, long currentPage)
{
//urlFmt => NewsController.ashx?action=list&pagenum={pagenum}
// newsIndex_{pagenum}.shtml
long totalPageCount = (long)Math.Ceiling((totalsize * 1.0 / pagesize)); //总页数
long pagebuttom = ; //8个页标
long firstpage = Math.Max(currentPage - pagebuttom, ); //第一个页标
long endpage = Math.Min(currentPage + pagebuttom, totalPageCount); //最后一个页标 StringBuilder sb = new StringBuilder();
if(firstpage>) //如果没有遍历到首页
{
string url = urlFmt.Replace("{pagenum}","");
sb.Append("<li><a href='").Append(url).Append("'>首页</a></li>");
} for (long i = firstpage; i <= endpage; i++)
{
string url = urlFmt.Replace("{pagenum}", i.ToString());
if (i == currentPage)
{
sb.Append("<li class='active'><a>第").Append(i).Append("页</a></li>");
}
else
{
sb.Append("<li><a href='").Append(url).Append("'>第").Append(i).Append("页</a></li>");
}
} if (endpage < totalPageCount) //如果没有遍历到末页
{
string url = urlFmt.Replace("{pagenum}", totalPageCount.ToString());
sb.Append("<li><a href='").Append(url).Append("'>末页</a></li>");
}
return new RawString(sb.ToString());
}
}
新闻列表 分页 一键静态化:
public void allNewsListStatic(HttpContext context)
{
#region 新闻列表 分页 一键静态化
AdminHelper.CheckHasPower(context, "新闻一键静态化");
string categoryidStr = context.Request["categoryid"];
int categoryid = VolidHelper.CheckStrToInt(categoryidStr);
TD_NEWSCATEGORY newscate = (TD_NEWSCATEGORY)myORM_BLL.SelectModelById(typeof(TD_NEWSCATEGORY), , categoryid);
long pagesize = ; //设置每页数量
long totalsize = myORM_BLL.SelectCountByField(typeof(TD_NEWS), , "Categoryid=" + categoryid); //总的新闻条数
long totalPageCount = (long)Math.Ceiling(totalsize * 1.0 / pagesize); //总页数
for (long i = ; i <= totalPageCount; i++) //遍历每一页
{
//对于每一页,获得该类别下的新闻集合
List<TD_NEWS> list = new NewsBLL().SelectNewsByCategoryidAndRownum(categoryid, (i - ) * pagesize + , i * pagesize);
string cshtml = RazorHelper.RazorParseHtml(context, "~/News/NewsListStatic.cshtml", new
{
categoryid = categoryid,
categoryName = newscate.NAME,
newses = list,
totalsize = totalsize,
pagesize = pagesize,
currentpage = i
});
//静态化
string pathPre = ConfigurationManager.AppSettings["ViewStaticDirecPre"]; //路径前缀
string fullPath = pathPre + categoryid + "\\newsIndex_" + i + ".shtml"; //全路径
string dir = Path.GetDirectoryName(fullPath);
if (!Directory.Exists(dir))
{
Directory.CreateDirectory(dir);
}
File.WriteAllText(fullPath, cshtml);
}
AdminHelper.RecordOperateLog(context, "新闻列表 一键静态化,其类别是:" + newscate.NAME);
context.Response.Redirect("/News/NewsController.ashx?action=list&categoryid=" + categoryid);
#endregion
}
NewsController.ashx
根据rownum查询的语句:
/// <summary>
/// 根据类别ID 按照NO排序 获得指定rownum之间的新闻集合
/// </summary>
/// <param name="categoryid">类别ID</param>
/// <param name="startnum">rownum起始数</param>
/// <param name="endnum">rownum结束数</param>
/// <returns>指定rownum之间的新闻集合</returns>
public List<TD_NEWS> SelectNewsByCategoryidAndRownum(long categoryid,long startnum ,long endnum)
{
string sql = @"SELECT * FROM (
SELECT ROW_NUMBER()OVER( order by NO asc) NUM,ID,NO,STATUS,CATEGORYID,CREATEBY,CREATEDATE,LASTEDITBY,LASTEDITDATE,DELETEBY,DELETEDATE,TITLE,CONTENT
FROM TD_NEWS WHERE STATUS=1 AND CATEGORYID=:CATEGORYID ) T
WHERE T.NUM>:startnum AND T.NUM<:startnum";
DataTable dt= OracleHelper.ExecuteReader(sql, new OracleParameter() { ParameterName = ":CATEGORYID", Value = categoryid },
new OracleParameter() { ParameterName = ":startnum", Value = startnum },
new OracleParameter() { ParameterName = ":startnum", Value = endnum });
List<TD_NEWS> list = new List<TD_NEWS>();
foreach(DataRow row in dt.Rows)
{
TD_NEWS news = RowToModel(row);
list.Add(news);
}
return list;
}
NewsDAL.cs
Pager分页的更多相关文章
- 自己写的一个Pager分页组件,WebForm,Mvc都适用
我一说写这个功能的时候,好多人估计有疑问.分页功能网上多的是,搜一个不就行了,你这样不是浪费时间么.你说这句话的时候,我是比较信的,首先自己写一些东西是很耗时,有这些时间又能多打几盘LOL了.但是我觉 ...
- ThinkPHP 3.2.3 Pager分页
不是很喜欢TP的分页类,因为生成的分页url感觉有点不好理解,例如访问路径xxxx/home/show.html,在模板输出分页后,例如产生了页码,页码链接的路径会变成xxxx/home/show/p ...
- JS案例之1——pager 分页
学习JS大半年之久,第一次自己尝试写一些小插件,写法参考网上某位牛人写代码的思路. 此处代码写的是静态分页.如果需动态分页,还可以修改下.第一次写,还有很多地方可以优化.希望各位大牛踊跃拍砖. 预览图 ...
- pager分页框架体会
<pg:pager> 元素的属性中: maxPageItems说的是每页偏移量是多少,这个并不是说每一页显示多少,而是第二页比第一页来说,在第一页的尾部增加多少,第一页又被覆盖多少,是决定 ...
- Vue Element Tabe Pager 分页方案
表格和分页分离的,但是使用中,却是结合在一起的. 分析 有以下方式触发查询: mounted 加载数据. 查询按钮 加载数据. pager 变化加载数据 加载数据函数: loadData 问题 mou ...
- JAVA 分页工具类及其使用
Pager.java package pers.kangxu.datautils.common; import java.io.Serializable; import java.util.List; ...
- asp.net mvc 自定义pager封装与优化
asp.net mvc 自定义pager封装与优化 Intro 之前做了一个通用的分页组件,但是有些不足,从翻页事件和分页样式都融合在后台代码中,到翻页事件可以自定义,再到翻页和样式都和代码分离, 自 ...
- asp.net mvc多条件+分页查询解决方案
开发环境vs2010 css:bootstrap js:jquery bootstrap paginator 原先只是想做个mvc的分页,但是一般的数据展现都需要检索条件,而且是多个条件,所以就变成了 ...
- MVC下分页的自定义分页一种实现
1.引言 在MVC开发中我们经常会对数据进行分页的展示.通过分页我们可以从服务端获取指定的数据来进行展示.这样既节约了数据库查询的时间也节约了网络传输的数据量.在MVC开发中使用的比较多的应该是MVC ...
随机推荐
- SecureCRT按退格键出现^H问题
1. 选择选项>>会话选项>>终端>>映射键
- SEM竞价数据基本分析方法
今天我们从账户数据表现来看一看怎样通过数据分析,判断账户出现的问题及解决思路.也欢迎大家提出意见,共同讨论进步. 首先我们从关键词报告来分析数据: 以上图数据为例.(设定该行业CPC均价为8) 先说下 ...
- PHP获取MySQL执行sql语句的查询时间
//计时开始 runtime(); //执行查询 mysql_query($sql); //计时结束. echo runtime(1); //计时函数 function runtime($mode=0 ...
- maven 内置属性有哪些?该如何使用?
maven 共有6类内置属性: 内置属性(maven预定义,用户可以直接使用的) ${basedir}表示项目的根目录,既包含pom.xml文件的目录: ${version}表示项目版本: ${pro ...
- Nuxt / Vue.js in TypeScript: Object literal may only specify known properties, but 'components' does not exist in type 'VueClass'
项目背景, Nuxt(vue), TypeScript 生成完项目框架, 添加测试demo页面. 在生成的模板代码中添加layout配置如下: <script lang="ts&quo ...
- Apache Phoenix的序列
序列作为标准SQL特性,允许生成递增的序列并应用在典型的ID中.为了创建一个序列,可以使用: 0:jdbc:phoenix:SZB-L0023780:2181:/hbase114> CREATE ...
- 让外界可以访问电脑上的网站的几种方式——花生壳,域名,IIS(待)
前话: 每次“养大“一个网站,都有种骄傲地想秀给朋友们看的冲动. 之前可能是困于电脑,实在不方便. 现在,不用克制了! 该秀就秀,能装逼就装逼. 养大孩子就该拉出来秀秀,见见世面. 正题:这次实习,我 ...
- Linux嵌入式 -- 内核 (arm) & 文件系统
1. make distclean 2. 配置内核 ----> 生成 .config文件 make menuconfig ARCH=arm Makefile文件分析: 3. 编译内核 mak ...
- MATLAB中feval与eval的区别
feval函数有两种调用形式1.[y1, y2, ...] = feval(fhandle, x1, ..., xn)2.[y1, y2, ...] = feval(fname, x1, ..., x ...
- Oracle中的BLOB和CLOB【转载】
原文地址:http://jelly.iteye.com/blog/65796 一.区别和定义 LONG: 可变长的字符串数据,最长2G,LONG具有VARCHAR2列的特性,可以存储长文本一个表中最多 ...