MVC下实现分页

菜鸟第一天                               

       作为菜鸟,记录以后可能会使用的到技术会使自己的未来更加轻松。。。。。。。。。。

       今天学习了在MVC下实现非插件式分页效果,通过创建一个分页方法,可以实现在任何需要进行分页的MVC页面上进行分页,直接在MVC页面上调用即可,废话不多说,直接上代码:

    分页的实现代码:       

 1 //返回一个拼接后的MvcHtmlString 字符串输出
 2 //this HtmlHelper pagehelper表示为MVC中的HTML添加拓展方法
 3 //area是在项目中创建了一个区域文件夹
 4 //action是函数名
 5 //controller是控制器
 6 //pagesize是html页面中显示的数量
 7 //totalcount是数据库中总数据的行数
 8 public static MvcHtmlString PageBarBulider(this HtmlHelper pagehelper, string area, string action, string controller, int pagesize, int totalcount)
 9 {
10 //从url参数pageindex获取当前的页索引
11 string currentpageindex = HttpContext.Current.Request.QueryString["pageindex"];
12 int icurrentPi = 1;
13 //由于第一次进入列表页面不会带有pageindex和pagesize,所以要赋值
14 //当为空的时候赋值1,表示第一次打开时默认获取第一页
15 if (string.IsNullOrEmpty(currentpageindex))
16 {
17 icurrentPi = 1;
18 }
19 else
20 {
21 icurrentPi = Convert.ToInt32(currentpageindex);
22 }
23 //通过天花板函数根据传过来的totalcount算出有多少页数据
24 decimal pagecount = Math.Ceiling(totalcount / Convert.ToDecimal(pagesize));
25 
26 
27 //1.0拼接当前分页控件使用的url,判断是否有区域
28 string areaPix = string.IsNullOrEmpty(area) ? "" : "/"+area;
29 string urlfmt = areaPix + "/" + controller + "/" + action + "?pageindex={0}&pagesize={1}";
30 
31 
32 StringBuilder sbhtml = new StringBuilder(200);
33 sbhtml.Append("<div id=pagebar><ul>");
34 sbhtml.Append("<li><a href=\""+string.Format(urlfmt,1,pagesize)+"\">首页</a></li>");
35 sbhtml.Append("<li><a href=\""+string.Format(urlfmt,icurrentPi==1?1:icurrentPi-1,pagesize)+"\">上一页</a></li>");
36 for (int i = 1; i <=pagecount; i++)
37 {
38 //如果当前选中,那么添加背景色
39 if (i == icurrentPi)
40 {
41 sbhtml.Append("<li><a style='color:#ff6a00;' href=\""+string.Format(urlfmt,i,pagesize)+"\">"+i+"<a></li>");
42 }
43 else
44 {
45 sbhtml.Append("<li><a href=\"" + string.Format(urlfmt, i, pagesize) + "\">" + i + "<a></li>");
46 }
47 }
48 sbhtml.Append("<li><a href=\""+string.Format(urlfmt,icurrentPi==pagecount?pagecount:icurrentPi+1,pagesize)+"\">下一页</a></li>");
49 sbhtml.Append("<li><a href=\""+string.Format(urlfmt,pagecount,pagesize)+"\">尾页</a></li>");
50 sbhtml.Append("</ul></div>");
51 //将拼接好的sbhtml转为字符串形式返回到Razor视图引擎解析
52 return new MvcHtmlString(sbhtml.ToString());

 

 上面写好了获取分页数据的方法,那么现在在某一个任意Razor视图上调用该方法,因为是HTML的拓展方法,那么可以在一个表格后面通过HTML.PageBarBulider(输入5个参数),具体如下:

  在上面调用后在第一次调用会出错的,因为View.totalcount还没有从控制器后台返回来,并且在第一次打开页面时要默认分页,所以在后台处理时,我们要先获取数据库中的总行数,同时还要判断如果是第一次打开则默认加载第一页数据,同时,因为在点击上一页和下一页的时候,已把url拼接成格式如下:

sbhtml.Append("<li><a href=\""+string.Format(urlfmt,icurrentPi==1?1:icurrentPi-1,pagesize)+"\">上一页</a></li>")类似于/Area/Controller/Action/pageindex=1&pagesize=5

所以控制器后台代码同时也要获取点击上一页或下一页的URL,根据URL后面的传递的指定参数从数据库中获取指定的数据,控制器中代码如下:

 1   public ActionResult Index()
 2         {
 3             //获取数据库中的总数据行,传给视图
 4             ViewBag.totalcount = categoryBLL.DbSet.Count();
 5 
 6             //1.0从url获取相关参数
 7             string pageindex = Request.QueryString["pageindex"];
 8             string pagesize = Request.QueryString["pagesize"];
 9             //2.0初始化页码和每页显示的数据
10             int ipageindex;
11             int ipagesize;
12             if (int.TryParse(pageindex, out ipageindex) == false)
13             {
14                 //如果转换不成功,那么就赋值为1,表示当前的第一页
15                 ipageindex = 1;
16             }
17             if (int.TryParse(pagesize, out ipagesize) == false)
18             {
19                 ipagesize = 5;
20             }
21             //3.0算出当前分页应该跳过的数据行数
22             int skipcount = (ipageindex - 1) * ipagesize;
23 
24             //4.0通过传递过来的参数获取数据库中指定行数据
25             var list = base.categoryBLL.DbSet.OrderByDescending(c => c.c_id).Skip(skipcount).Take(ipagesize).ToList();
26 
27             //5.0EntityMap()方法是将MVC中的自定义的实体转为EF自动生成的实体,同样的,可以通过new匿名来进行转换
28             var listmodeview = list.Select(c => c.EntityMap());
29 
30             return View(listmodeview);
31         }

 

  第一次写博客,有点紧张,有错请指点,不喜勿喷!

 

 

 

 

posted @ 2014-03-27 23:36  jean69  阅读(760)  评论(0编辑  收藏  举报