Asp.net mvc 3 MVC 3+WebGrid:分页控件不显示
我在为WebGrid分页时遇到问题。基本上,我传递了完整的数据,它可以。如果我将数据一次限制为一页,则分页控件将消失,尽管我已传入行数 为什么? 有关设置,请参见以下内容: 我有一个网格定义如下:Asp.net mvc 3 MVC 3+WebGrid:分页控件不显示,asp.net-mvc-3,webgrid,Asp.net Mvc 3,Webgrid,我在为WebGrid分页时遇到问题。基本上,我传递了完整的数据,它可以。如果我将数据一次限制为一页,则分页控件将消失,尽管我已传入行数 为什么? 有关设置,请参见以下内容: 我有一个网格定义如下: @{ ViewBag.Title = "Cuentas"; var grid = new WebGrid(defaultSort: "AccountName", rowsPerPage: 30, canPage: true, ajaxUpdateCallback: "
@{
ViewBag.Title = "Cuentas";
var grid = new WebGrid(defaultSort: "AccountName", rowsPerPage: 30, canPage: true,
ajaxUpdateCallback: "updateGrid");
grid.Bind(source: Model.Accounts, rowCount: Model.TotalRows);
}
<div id="grid">
@grid.GetHtml(tableStyle:"grid",headerStyle:"head", alternatingRowStyle:"alt", htmlAttributes: new { id = "AccountsGrid"},
columns: grid.Columns(grid.Column(header: "", format: (item) => Html.ActionLink("Editar", "Edit", new { id = item.AccountId })),
grid.Column(header: "", format: (item) => Html.ActionLink("Eliminar", "Delete", new { id = item.AccountId })),
grid.Column("AccountName",header:"Nombre"),
grid.Column("IsClient", header:"Cliente?"),
grid.Column("IsProvider", header:"Proveedor?"),
grid.Column("IsBank", header:"Banco o Caja?"),
grid.Column("Person", format: item => new HtmlString(item.Person == null ? "" : item.Person.Name), header: "Contacto"),
grid.Column("AccountsCostCentress",
format: item => new HtmlString(item.AccountsCostCentress == null ?
"" : item.AccountsCostCentress.Count.ToString()), header: "Actividades")))
</div>
public class AccountsListViewModel
{
public int PageSize { get; set; }
public int PageNumber { get; set; }
public IEnumerable<Account> Accounts { get; set; }
public int TotalRows {get;set;}
}
其列定义如下:
@{
ViewBag.Title = "Cuentas";
var grid = new WebGrid(defaultSort: "AccountName", rowsPerPage: 30, canPage: true,
ajaxUpdateCallback: "updateGrid");
grid.Bind(source: Model.Accounts, rowCount: Model.TotalRows);
}
<div id="grid">
@grid.GetHtml(tableStyle:"grid",headerStyle:"head", alternatingRowStyle:"alt", htmlAttributes: new { id = "AccountsGrid"},
columns: grid.Columns(grid.Column(header: "", format: (item) => Html.ActionLink("Editar", "Edit", new { id = item.AccountId })),
grid.Column(header: "", format: (item) => Html.ActionLink("Eliminar", "Delete", new { id = item.AccountId })),
grid.Column("AccountName",header:"Nombre"),
grid.Column("IsClient", header:"Cliente?"),
grid.Column("IsProvider", header:"Proveedor?"),
grid.Column("IsBank", header:"Banco o Caja?"),
grid.Column("Person", format: item => new HtmlString(item.Person == null ? "" : item.Person.Name), header: "Contacto"),
grid.Column("AccountsCostCentress",
format: item => new HtmlString(item.AccountsCostCentress == null ?
"" : item.AccountsCostCentress.Count.ToString()), header: "Actividades")))
</div>
public class AccountsListViewModel
{
public int PageSize { get; set; }
public int PageNumber { get; set; }
public IEnumerable<Account> Accounts { get; set; }
public int TotalRows {get;set;}
}
我在视图中使用的ViewModel定义如下:
@{
ViewBag.Title = "Cuentas";
var grid = new WebGrid(defaultSort: "AccountName", rowsPerPage: 30, canPage: true,
ajaxUpdateCallback: "updateGrid");
grid.Bind(source: Model.Accounts, rowCount: Model.TotalRows);
}
<div id="grid">
@grid.GetHtml(tableStyle:"grid",headerStyle:"head", alternatingRowStyle:"alt", htmlAttributes: new { id = "AccountsGrid"},
columns: grid.Columns(grid.Column(header: "", format: (item) => Html.ActionLink("Editar", "Edit", new { id = item.AccountId })),
grid.Column(header: "", format: (item) => Html.ActionLink("Eliminar", "Delete", new { id = item.AccountId })),
grid.Column("AccountName",header:"Nombre"),
grid.Column("IsClient", header:"Cliente?"),
grid.Column("IsProvider", header:"Proveedor?"),
grid.Column("IsBank", header:"Banco o Caja?"),
grid.Column("Person", format: item => new HtmlString(item.Person == null ? "" : item.Person.Name), header: "Contacto"),
grid.Column("AccountsCostCentress",
format: item => new HtmlString(item.AccountsCostCentress == null ?
"" : item.AccountsCostCentress.Count.ToString()), header: "Actividades")))
</div>
public class AccountsListViewModel
{
public int PageSize { get; set; }
public int PageNumber { get; set; }
public IEnumerable<Account> Accounts { get; set; }
public int TotalRows {get;set;}
}
这表明我可以传递rowCount和IEnumerable帐户
假设我有305行帐户。如果我将PageSize设置为30,这意味着我将有11页数据,最后一页上只有5条记录。如果Accounts保存所有305条记录,那么网格将使用分页和all
例如,如果Accounts仅保存与第3页对应的30条记录,则分页控件不会显示,即使TotalRows==305
我想不出来。你能?或者你知道我可能会看的博客帖子、帖子或文章吗???对不起!回答了我自己的问题: autoSortPage:网格中缺少假参数。绑定。。。方法 请参见以下内容: