首页 > 其他 > 详细

C#_Ajax_分页

时间:2014-05-25 13:50:42      阅读:496      评论:0      收藏:0      [点我收藏+]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
 
namespace MvcTest.Extends
{
    /// <summary>
    /// 分页元素位置
    /// </summary>
    public enum PagerElementPosition
    {
        Left,
        Right
    }
    public class PagerConfig
    {
        /// <summary>
        /// 记录总条数
        /// </summary>
        public int TotalRecord { get; set; }
        /// <summary>
        /// 记录的单位,默认为“条”
        /// </summary>
        public string RecordUnit { get; set; }
        /// <summary>
        /// 记录的名称,默认为“记录”
        /// </summary>
        public string RecordName { get; set; }
        /// <summary>
        /// 当前页码的参数名
        /// </summary>
        public string CurrentPageKey { get; set; }
        /// <summary>
        /// 当前页码 只读
        /// </summary>
        public int CurrentPage
        {
            get
            {
                if (HttpContext.Current.Request.Params[CurrentPageKey] == null)
                {
                    return 1;
                }
                else
                {
                    try
                    {
                        int currentPage = Convert.ToInt32(HttpContext.Current.Request.Params[CurrentPageKey]);
                        if (currentPage < 1)
                        {
                            return 1;
                        }
                        else if (currentPage > TotalPage)
                        {
                            return TotalPage;
                        }
                        else
                        {
                            return currentPage;
                        }
                    }
                    catch
                    {
                        return 1;
                    }
                }
            }
        }
        private int _PageSize;
        /// <summary>
        /// 每页显示记录数
        /// </summary>
        public int PageSize
        {
            get
            {
                return _PageSize;
            }
            set
            {
                if (value < 1)
                {
                    _PageSize = 1;
                }
                else
                {
                    _PageSize = value;
                }
            }
        }
        /// <summary>
        /// 总页数 只读
        /// </summary>
        public int TotalPage
        {
            get
            {
                return (int)Math.Ceiling(TotalRecord / (double)PageSize);
            }
        }
        /// <summary>
        /// 是否显示首页、尾页链接
        /// </summary>
        public bool ShowFirstLastPageLink { get; set; }
        /// <summary>
        /// 是否显示上一页、下一页链接
        /// </summary>
        public bool ShowPrevNextPageLink { get; set; }
        /// <summary>
        /// 是否显示数字按钮
        /// </summary>
        public bool ShowDigitalLink { get; set; }
        /// <summary>
        /// 数字按钮数量
        /// </summary>
        public int DigitalLinkCount { get; set; }
        /// <summary>
        /// 是否显示总记录数
        /// </summary>
        public bool ShowTotalRecord { get; set; }
        /// <summary>
        /// 总记录数出现位置
        /// </summary>
        public PagerElementPosition TotalRecordPosition { get; set; }
        /// <summary>
        /// 是否显示当前页数和总页数信息
        /// </summary>
        public bool ShowPageInfo { get; set; }
        /// <summary>
        /// 当前页和总页数信息显示位置
        /// </summary>
        public PagerElementPosition PageInfoPosition { get; set; }
        /// <summary>
        /// 是否显示GoTo输入区域
        /// </summary>
        public bool ShowGoTo { get; set; }
        /// <summary>
        /// 指定生成的元素对应的class的前缀字符
        /// </summary>
        public string CssClassPreWord { get; set; }
        /// <summary>
        /// 是否创建为ajax分页控件
        /// </summary>
        public bool UseAjax { get; set; }
        /// <summary>
        /// Ajax提交后更新的html元素id
        /// </summary>
        public string AjaxUpdateTargetID { get; set; }
        /// <summary>
        /// Ajax提交后调用的js function名称
        /// </summary>
        public string AjaxSuccessFunctionName { get; set; }
        /// <summary>
        /// 是否自动生成Ajax提交后调用的js function
        /// </summary>
        public bool AutoGenarateAjaxSuccessFunction { get; set; }
        /// <summary>
        /// 使用默认值初始化设置
        /// </summary>
        public PagerConfig()
        {
            PageSize = 4;
            RecordUnit = "条";
            RecordName = "记录";
            CurrentPageKey = "page";
            CssClassPreWord = "pager";
            ShowFirstLastPageLink = true;
            ShowPrevNextPageLink = true;
            ShowDigitalLink = true;
            DigitalLinkCount = 10;
            ShowTotalRecord = false;
            TotalRecordPosition = PagerElementPosition.Left;
            ShowPageInfo = false;
            PageInfoPosition = PagerElementPosition.Left;
            ShowGoTo = false;
            UseAjax = false;
            AjaxUpdateTargetID = "";
            AjaxSuccessFunctionName = "OnPageChanged";
            AutoGenarateAjaxSuccessFunction = true;
        }
    }
    /// <summary>
    /// 配合Pager扩展实现分页的帮助类
    /// </summary>
    public class PagerHelper
    {
        /// <summary>
        /// 获取记录开始和结束编号,并返回实际的页码
        /// </summary>
        /// <param name="allCount">记录总条数</param>
        /// <param name="pageSize">页大小</param>
        /// <param name="pageIndex">(输出)当前页码</param>
        /// <param name="startIndex">(输出)开始编号</param>
        /// <param name="endIndex">(输出)结束编号</param>
        /// <param name="currentPageKey">分页参数名称</param>
        /// <param name="pageIndexIs0Based">页码编号是否从0开始,默认为否</param>
        /// <param name="recordIndexIs0Based">记录编号是否从0开始,默认为否</param>
        public static void GetStartAndEndIndex(int allCount, int pageSize, out int pageIndex, out int startIndex, out int endIndex, string currentPageKey = "page", bool pageIndexIs0Based = false, bool recordIndexIs0Based = false)
        {
            //计算pageIndex的实际值
            pageIndex = GetRealPageIndex(allCount, pageSize, currentPageKey, pageIndexIs0Based);
 
            //计算过程是0based的
            if (!pageIndexIs0Based)
            {
                pageIndex--;  //转成0based
            }
            //计算startIndex和endIndex
            startIndex = pageIndex * pageSize;
            endIndex = startIndex + pageSize - 1;
            if (endIndex > allCount - 1)
            {
                endIndex = allCount - 1;
            }
 
            //0based计算完成,下面根据设置不同,输出不同
            if (!pageIndexIs0Based)
            {
                pageIndex++;
            }
            if (!recordIndexIs0Based)
            {
                startIndex++;
                endIndex++;
            }
        }
 
        /// <summary>
        /// 返回实际页码
        /// </summary>
        /// <param name="allCount">总记录数</param>
        /// <param name="pageSize">页面大小</param>
        /// <param name="currentPageKey">分页参数名称</param>
        /// <param name="pageIndexIs0Based">页码编号是否从0开始,默认为否</param>
        /// <returns>实际页码</returns>
        public static int GetRealPageIndex(int allCount, int pageSize, string currentPageKey = "page", bool pageIndexIs0Based = false)
        {
            int pageIndex;
            //整个计算过程都是0based的
            if (pageSize < 1)
            {
                pageSize = 1; //容错
            }
            if (HttpContext.Current.Request.Params[currentPageKey] == null)
            {
                pageIndex = 0;
            }
            else
            {
                try
                {
                    int _pageIndex = Convert.ToInt32(HttpContext.Current.Request.Params[currentPageKey]);   //待判断的页码
                    if (!pageIndexIs0Based)
                    {
                        _pageIndex--;   //转成0based
                    }
                    if (_pageIndex < 0)
                    {
                        pageIndex = 0;
                    }
                    else
                    {
                        int totalPage = (int)Math.Ceiling(allCount / (double)pageSize);
                        if (_pageIndex >= totalPage)
                        {
                            pageIndex = totalPage - 1;
                        }
                        else
                        {
                            pageIndex = _pageIndex;
                        }
                    }
                }
                catch
                {
                    pageIndex = 0;
                }
            }
            //0based计算完成,下面根据设置不同,输出不同
            return (pageIndexIs0Based) ? pageIndex : pageIndex + 1;
        }
 
    }
}

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
using MvcTest.Extends;
using System;
using System.Collections.Generic;
using System.Linq;
 
using System.Text;
using System.Web;
using System.Web.Mvc;
using System.Web.Routing;
 
namespace MvcTest.HTML
{
    public static class PagerExtensions
    {
        //提取 返回a标签 方法
        private static string getLinkHtml(UrlHelper urlHelper, bool useAjax, string ajaxSuccessFunction, string linkContent, string actionName, string controllerName, RouteValueDictionary routeValues)
        {
            string link = "";
            if (useAjax)
            {
                link += "<a href=\"javascript:$.post(‘" + urlHelper.Action(actionName, controllerName) + "‘,{";
                //将route放到post表单中
                foreach (var route in routeValues.Keys)
                {
                    link += route + ":‘" + routeValues[route].ToString() + "‘,";
                }
                if (routeValues.Count > 0)
                {
                    link = link.Remove(link.Length - 1);
                }
                link += "}," + ajaxSuccessFunction + ")\" >";
            }
            else
            {
                link += "<a href=\"" + urlHelper.Action(actionName, controllerName, routeValues) + "\">";
            }
            link += linkContent;
            link += "</a>";
            return link;
        }
 
        #region 分页扩展
 
        /// <summary>
        /// 返回用于分页的div元素
        /// </summary>
        /// <param name="htmlHelper">HtmlHelper</param>
        /// <param name="pagerConfig">分页设置对象</param>
        /// <returns></returns>
        public static MvcHtmlString Pager(this HtmlHelper htmlHelper, PagerConfig pagerConfig)
        {
            return Pager(htmlHelper, "", "", new { }, new { }, pagerConfig);
        }
 
        /// <summary>
        /// 返回用于分页的div元素
        /// </summary>
        /// <param name="htmlHelper">HtmlHelper</param>
        /// <param name="htmlAttributes">html属性对象</param>
        /// <param name="pagerConfig">分页设置对象</param>
        /// <returns></returns>
        public static MvcHtmlString Pager(this HtmlHelper htmlHelper, object htmlAttributes, PagerConfig pagerConfig)
        {
            return Pager(htmlHelper, "", "", new { }, htmlAttributes, pagerConfig);
        }
        /// <summary>
        /// 返回用于分页的div元素
        /// </summary>
        /// <param name="htmlHelper">HtmlHelper</param>
        /// <param name="actionName">方法</param>
        /// <param name="htmlAttributes">html属性对象</param>
        /// <param name="pagerConfig">分页设置对象</param>
        /// <returns></returns>
        public static MvcHtmlString Pager(this HtmlHelper htmlHelper, string actionName, object htmlAttributes, PagerConfig pagerConfig)
        {
            return Pager(htmlHelper, actionName, "", new { }, htmlAttributes, pagerConfig);
        }
        /// <summary>
        /// 返回用于分页的div元素
        /// </summary>
        /// <param name="htmlHelper">HtmlHelper</param>
        /// <param name="actionName">方法</param>
        /// <param name="controllerName">控制器</param>
        /// <param name="htmlAttributes">html属性对象</param>
        /// <param name="pagerConfig">分页设置对象</param>
        /// <returns></returns>
        public static MvcHtmlString Pager(this HtmlHelper htmlHelper, string actionName, string controllerName, object htmlAttributes, PagerConfig pagerConfig)
        {
            return Pager(htmlHelper, actionName, controllerName, new { }, htmlAttributes, pagerConfig);
        }
        /// <summary>
        /// 返回用于分页的div元素
        /// </summary>
        /// <param name="htmlHelper">HtmlHelper</param>
        /// <param name="actionName">方法</param>
        /// <param name="controllerName">控制器</param>
        /// <param name="routeValues">路由参数</param>
        /// <param name="htmlAttributes">html属性对象</param>
        /// <param name="pagerConfig">分页设置对象</param>
        /// <returns></returns>
        public static MvcHtmlString Pager(this HtmlHelper htmlHelper, string actionName, string controllerName, object routeValues, object htmlAttributes, PagerConfig pagerConfig)
        {
 
            RouteValueDictionary RouteValues;
            if (routeValues == null)
            {
                RouteValues = new RouteValueDictionary();
            }
            else
            {
                RouteValues = new RouteValueDictionary(routeValues);
            }
 
            UrlHelper Url = new UrlHelper(htmlHelper.ViewContext.RequestContext);
            AjaxHelper Ajax = new AjaxHelper(htmlHelper.ViewContext, htmlHelper.ViewDataContainer);
 
            StringBuilder sbPager = new StringBuilder();
            sbPager.Append("<div");
            //利用反射获取htmlAttributes的全部元素和值
            if (htmlAttributes != null)
            {
                System.Reflection.PropertyInfo[] htmlProperties = (System.Reflection.PropertyInfo[])htmlAttributes.GetType().GetProperties();
                foreach (var property in htmlProperties)
                {
                    sbPager.Append(" " + property.Name + "=\"" + property.GetValue(htmlAttributes).ToString() + "\"");
                }
            }
            sbPager.Append(">");
            //左侧记录总数信息
            if (pagerConfig.ShowTotalRecord && pagerConfig.PageInfoPosition == PagerElementPosition.Left)
            {
                sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-count\">共" + pagerConfig.TotalRecord + pagerConfig.RecordUnit + pagerConfig.RecordName + "</span>");
            }
            //左侧页码信息
            if (pagerConfig.ShowPageInfo && pagerConfig.PageInfoPosition == PagerElementPosition.Left)
            {
                sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-info\">第" + pagerConfig.CurrentPage + "页/共" + pagerConfig.TotalPage + "页</span>");
            }
            //首页
            if (pagerConfig.ShowFirstLastPageLink)
            {
                if (pagerConfig.CurrentPage > 1)
                {
                    RouteValues[pagerConfig.CurrentPageKey] = 1;
                    sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-btn\">" + getLinkHtml(Url, pagerConfig.UseAjax, pagerConfig.AjaxSuccessFunctionName, "首页", actionName, controllerName, RouteValues) + "</span>");
                }
                else
                {
                    sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-btn\">首页</span>");
                }
            }
            //上一页
            if (pagerConfig.ShowPrevNextPageLink)
            {
                if (pagerConfig.CurrentPage > 1)
                {
                    RouteValues[pagerConfig.CurrentPageKey] = pagerConfig.CurrentPage - 1;
                    sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-btn\">" + getLinkHtml(Url, pagerConfig.UseAjax, pagerConfig.AjaxSuccessFunctionName, "上一页", actionName, controllerName, RouteValues) + "</span>");
                }
                else
                {
                    sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-btn\">上一页</span>");
                }
            }
            //数字导航开始
            if (pagerConfig.ShowDigitalLink)
            {
 
                int shownStartPageIndex, shownEndPageIndex;
                //总页数少于要显示的页数,页码全部显示
                if (pagerConfig.DigitalLinkCount >= pagerConfig.TotalPage)
                {
                    shownStartPageIndex = 1;
                    shownEndPageIndex = pagerConfig.TotalPage;
                }
                else//显示指定数量的页码
                {
                    int forward = (int)Math.Ceiling(pagerConfig.DigitalLinkCount / 2.0);
                    if (pagerConfig.CurrentPage > forward)//起始页码大于1
                    {
                        shownEndPageIndex = pagerConfig.CurrentPage + pagerConfig.DigitalLinkCount - forward;
                        if (shownEndPageIndex > pagerConfig.TotalPage)//结束页码大于总页码结束页码为最后一页
                        {
                            shownStartPageIndex = pagerConfig.TotalPage - pagerConfig.DigitalLinkCount + 1;
                            shownEndPageIndex = pagerConfig.TotalPage;
 
                        }
                        else
                        {
                            shownStartPageIndex = pagerConfig.CurrentPage - forward + 1;
                        }
                    }
                    else//起始页码从1开始
                    {
                        shownStartPageIndex = 1;
                        shownEndPageIndex = pagerConfig.DigitalLinkCount;
                    }
                }
                //向上…
                if (shownStartPageIndex > 1)
                {
                    RouteValues[pagerConfig.CurrentPageKey] = shownStartPageIndex - 1;
                    sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-number\">" + getLinkHtml(Url, pagerConfig.UseAjax, pagerConfig.AjaxSuccessFunctionName, "...", actionName, controllerName, RouteValues) + "</span>");
                }
                //数字
                for (int i = shownStartPageIndex; i <= shownEndPageIndex; i++)
                {
                    if (i != pagerConfig.CurrentPage)
                    {
                        RouteValues[pagerConfig.CurrentPageKey] = i;
                        sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-number\">" + getLinkHtml(Url, pagerConfig.UseAjax, pagerConfig.AjaxSuccessFunctionName, i.ToString(), actionName, controllerName, RouteValues) + "</span>");
                    }
                    else
                    {
                        sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-number " + pagerConfig.CssClassPreWord + "-currentnum\">" + i.ToString() + "</span>");
                    }
                }
                //向下…
                if (shownEndPageIndex < pagerConfig.TotalPage)
                {
                    RouteValues[pagerConfig.CurrentPageKey] = shownEndPageIndex + 1;
                    sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-number\">" + getLinkHtml(Url, pagerConfig.UseAjax, pagerConfig.AjaxSuccessFunctionName, "...", actionName, controllerName, RouteValues) + "</span>");
                }
            }
            ////数字导航结束
 
            //下一页
            if (pagerConfig.ShowPrevNextPageLink)
            {
                if (pagerConfig.CurrentPage < pagerConfig.TotalPage)
                {
                    RouteValues[pagerConfig.CurrentPageKey] = pagerConfig.CurrentPage + 1;
                    sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-btn\">" + getLinkHtml(Url, pagerConfig.UseAjax, pagerConfig.AjaxSuccessFunctionName, "下一页", actionName, controllerName, RouteValues) + "</span>");
                }
                else
                {
                    sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-btn\">下一页</span>");
                }
            }
            //尾页
            if (pagerConfig.ShowFirstLastPageLink)
 
            {
                if (pagerConfig.CurrentPage < pagerConfig.TotalPage)
                {
 
                    RouteValues[pagerConfig.CurrentPageKey] = pagerConfig.TotalPage;
                    sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-btn\">" + getLinkHtml(Url, pagerConfig.UseAjax, pagerConfig.AjaxSuccessFunctionName, "尾页", actionName, controllerName, RouteValues) + "</span>");
                }
                else
                {
                    sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-btn\">尾页</span>");
 
                }
            }
 
            //右侧记录总数信息
            if (pagerConfig.ShowTotalRecord && pagerConfig.PageInfoPosition == PagerElementPosition.Right)
            {
                sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-count\">共" + pagerConfig.TotalRecord + pagerConfig.RecordUnit + pagerConfig.RecordName + "</span>");
            }
            //右侧页码信息
            if (pagerConfig.ShowPageInfo && pagerConfig.PageInfoPosition == PagerElementPosition.Right)
            {
                sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-info\">第" + pagerConfig.CurrentPage + "页/共" + pagerConfig.TotalPage + "页</span>");
            }
 
            //页码输入框
            if (pagerConfig.ShowGoTo)
            {
 
                RouteValues[pagerConfig.CurrentPageKey] = "--pageRouteValue--";
                sbPager.Append("<span class=\"" + pagerConfig.CssClassPreWord + "-goto\">转到第<input class=\"" + pagerConfig.CssClassPreWord + "-goto-input\" type=\"text\" url=\"" + Url.Action(actionName, controllerName, RouteValues) + "\" />页");
 
                if (pagerConfig.UseAjax)
                {
                    sbPager.Append("<input class=\"" + pagerConfig.CssClassPreWord + "-goto-submit\" type=\"button\" value=\"GO\" onclick=\"$.post( $(this).prev().attr(‘url‘).replace(‘--pageRouteValue--‘,$(this).prev().val())," + pagerConfig.AjaxSuccessFunctionName + ")\" /></span>");
                }
                else
                {
                    sbPager.Append("<input class=\"" + pagerConfig.CssClassPreWord + "-goto-submit\" type=\"button\" value=\"GO\" onclick=\"window.location = $(this).prev().attr(‘url‘).replace(‘--pageRouteValue--‘,$(this).prev().val());\" /></span>");
                }
            }
            //ajax分页回调函数
            if (pagerConfig.UseAjax)
            {
                if (pagerConfig.AutoGenarateAjaxSuccessFunction)
                {
                    sbPager.Append("<script type=\"text/javascript\">function " + pagerConfig.AjaxSuccessFunctionName + "(data){$(‘#" + pagerConfig.AjaxUpdateTargetID + "‘).html(data);}</script>");
                }
            }
            sbPager.Append("</div>");
            return MvcHtmlString.Create(sbPager.ToString());
        }
 
        #endregion
 
    }
}

 

调用

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
public ActionResult Index()
   {
       int pageSize = 4;
       int allCount = db.Movies.Count();
       ViewBag.Num = allCount;
       ViewBag.PageSize = pageSize;
       int pageIndex, startIndex, endIndex;
       //获取开始和结束的记录序号
       PagerHelper.GetStartAndEndIndex(allCount, pageSize, out pageIndex, out startIndex, out endIndex);
       //调用存储过程返回指定序号范围的数据
      // return View(db.SelectUserList(startIndex, endIndex));
 
       var sear = (from m in db.Movies where m.ID >= startIndex && m.ID <= endIndex select m).ToList();
       return View(sear);
       //return View(db.Movies.ToList());
   }

 

@Html.Pager("Index", "Movies", new { }, new PagerConfig { TotalRecord = ViewBag.Num, PageSize = ViewBag.PageSize })

C#_Ajax_分页,布布扣,bubuko.com

C#_Ajax_分页

原文:http://www.cnblogs.com/MarchThree/p/3751053.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!