我在 MVC4 + EXT.NET 库项目中创建 StoreResult 控制器,以响应 GridPanel() 中的 JsonReader()。我的控制器返回字符串 Ext.Net.MVC.StoreResult 而不是 json 数据。我在 VS2012、IIS8、MVC4 中创建项目。
谢谢你帮助我。
// IN VIEW
@(Html.X().GridPanel()
.ID("GridPanel1")
.Title("Array Grid")
.Width(600)
.Height(350)
.Store(s => s.Add(Html.X().Store()
.PageSize(100)
.Buffered(true)
.AutoLoad(false)
.Proxy(proxy=>proxy.Add(Html.X().AjaxProxy()
.Url("/Data/GetData")
.Reader(reader=>reader.Add(Html.X().JsonReader()
.Root("data")))
))
.Model(model => model.Add(Html.X().Model()
.Fields(field =>
{
field.Add(Html.X().ModelField().Name("UserId"));
field.Add(Html.X().ModelField().Name("UserName"));
})
))
))
.VerticalScroller(scroller => scroller.Add(Html.X().GridPagingScroller()))
.ColumnModel(columnModel =>
{
columnModel.Columns.Add(Html.X().Column()
.Text("UserId")
.DataIndex("UserID")
.Flex(1)
.Width(70));
columnModel.Columns.Add(Html.X().Column()
.Text("UserName")
.DataIndex("UserName")
.Flex(1));
columnModel.Columns.Add(Html.X().Column()
.Text("UserPassword")
.DataIndex("UserPassword")
.Flex(1));
})
.View(view => view.Add(Html.X().GridView().TrackOver(false)))
.Listeners(listeners =>
{
listeners.AfterRender.Handler = "this.store.guaranteeRange(0,99);";
listeners.AfterRender.Delay = 100;
})
)
///////// IN CONTROLLER
public class DataController : System.Web.Mvc.Controller
{
//
// GET: /Data/GetData/
public Ext.Net.MVC.StoreResult GetData(int page = 1, int start = 0, int limit = 100)
{
StoreResult responce = new StoreResult();
List<UserList> UserList = new List<UserList>();
for (int i = start + 1; i <= start + limit; i++)
{
UserList user = new UserList()
{
UserId = i,
UserName = "UserName " + i
};
UserList.Add(user);
}
responce.Data = UserList;
responce.Total = 50000;
return responce;
}
}