问题是分页在第 9 页码之前工作正常,当我请求两位数或更多位数的页面时,它会占用最后一位数字并忽略其余数字,例如,如果我请求页码 10,那么它会显示通过将“?page = 0”作为查询字符串传递给第0页并丢弃1,如果我请求页码例如458,那么它通过将“?page = 8”作为查询字符串传递并丢弃45来显示页码8 458. 这是我的代码:
在 Javacsript 中:
$(function () {
$('tfoot a').click(function () {
// try to extract the page number from the link
var page = this.href.match(/page=([0-9])+/)[1];
// submit the form so that the POST action is invoked
var form = document.forms[0];
form.action = '/Session/Index?page=' + page;
form.submit();
return false;
});
});
</script>
鉴于:
var grid = new WebGrid(source: Model.ListSessions, rowsPerPage: 5,
canPage: true, canSort: false, defaultSort: "Absentee");
@grid.GetHtml(
htmlAttributes: new { id = "grid" },
tableStyle: "grid",
headerStyle: "head",
alternatingRowStyle: "alt",
columns: grid.Columns(
grid.Column(format: @<text> <input type="hidden" id="ColorCodeValue" name="ColorCodeValue" value="@item.ColorCodeValue" /> </text>, style: "width:0px;"),
grid.Column("CreatedBy", "Created By"),
grid.Column("Session Title", format: (item) => Html.ActionLink((string)item.SessionTitle, MVC.Session.ActionNames.EditSession,
new { id = item.SessionId })),
grid.Column("SessionID", "Simple Session ID"),
grid.Column("StartDate", "Start Date"),
grid.Column("StartTime", "Start Time"),
grid.Column("SessionStatus", "Status"),
grid.Column("Prep Materials", format: @<text><a onclick="SessionClick();" id="@item.EnableViewLink" href="@Url.Action(MVC.Session.Actions.ViewSession((string)item.SessionID))">View</a><a id="UploadSessionMaterial" href="@Url.Action(MVC.Session.Actions.UploadSession((Int32)item.SessionId))">Upload</a> </text>),
grid.Column("Action", format: @<text><a href="@Url.Action(MVC.Session.Actions.ViewSession((int)item.SessionId))">View</a><a id="@item.IsPublished" class="@item.IsTranscriptExists" href="@Url.Action(MVC.Session.Actions.EditTranscript((Int32)item.SessionId))">Edited Session </a></text>)
), mode: WebGridPagerModes.All)
在控制器中:
[HttpPost]
public virtual ActionResult Index(SessionViewModel model)
{
model = GetSessionListing(model);
return View(model);
}
private SessionViewModel GetSessionListing(SessionViewModel model)
{
if (model == null)
{
model = new SessionViewModel();
}
int page = 1;
if (Convert.ToInt64( Request["page"]) != null)
int.TryParse(Request["page"], out page);
//Rest of Coding here
return model;
}
任何帮助都会很棒!如果您仍然需要询问更多内容,请询问我。谢谢!