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 ...
随机推荐
- VS中一个强大的功能,将Json或者XML黏贴为类
有时候需要传递json,或者是json结构复杂,看的杂乱无章,我们可以将这个json复制下来,然后将它写成类的形式,VS中已经帮我们很好的实现了这个功能,我们只需要选择 编辑===>> ...
- 使用fastboot刷机流程【转】
本文转载自:http://www.voidcn.com/blog/Qidi_Huang/article/p-6236224.html [准备工作] 首先需要准备好刷机包,可以是自己编译的,也可以是从别 ...
- 在Linux终端中查看公有IP的方法详解
首先回顾一下一般的查看IP的命令: ifconfigLinux查看IP地址的命令--ifconfigifconfig命令用于查看和更改网络接口的地址和参数 $ifconfig -a lo0: fla ...
- 【bzoj1345】[Baltic2007]序列问题Sequence
题目传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=1345 因为合并的花费是较大数的权值,所以每个数肯定是和附近的小数合并完后才与大数合并, ...
- Hadoop的Docker镜像构建
1.Dockerfile ###Dockerfile -- beagin FROM ubuntu:trusty #MAINTAINER The Hue Team "https://githu ...
- 轻松掌握XMLHttpRequest对象------【这是.net 版本】
轻松掌握XMLHttpRequest对象 XmlHttp是什么? 最通用的定义为:XmlHttp是一套可以在Javascript.VbScript.Jscript等脚本语言中通过http协议传送或从接 ...
- Java编程思想 Random(47)
Random类包含两个构造方法,下面依次进行介绍:1. public Random()该构造方法使用一个和当前系统时间对应的相对时间有关的数字作为种子数,然后使用这个种子数构造Random对象.2. ...
- numpy函数:[6]arange()详解
arange函数用于创建等差数组,使用频率非常高,arange非常类似range函数,会python的人肯定经常用range函数,比如在for循环中,几乎都用到了range,下面我们通过range来学 ...
- 《Advanced Bash-scripting Guide》学习(十七):用more来查看gzip文件
本文所选的例子来自于<Advanced Bash-scripting Gudie>一书,译者 杨春敏 黄毅 #!/bin/bash #使用more查看gzip文件 NOARGS= NOTF ...
- 字符串数组是可以保存并输出null。只不过不好动态指定长度
java里如何输出才能让字符串数组不显示出null 2014-05-23 17:46笨妞纤霏 | 浏览 1360 次 编程语言 代码如下package testCourse; public clas ...