我有一个网格:
@(Html.Grid("grid")
.SetJsonReader(new MvcJqGrid.DataReaders.JsonReader { Id = "Id", RepeatItems = false })
.SetRequestType(RequestType.Post)
.AddColumn(new Column("Date").SetWidth(300).SetLabel("Date").)
.SetUrl(Url.Action("Action", "Controller"))
.SetRowNum(10)
.SetHeight(500)
.SetRowList(new[] { 10, 15, 20, 50 })
.SetViewRecords(true)
.SetGridView(true)
.SetPager("pager")
)
和此网格的数据:
[HttpPost]
public JsonResult Action(GridSettings gridSettings)
{
var data = new List<DateTime>();
data.AddRange(Enumerable.Range(0, 1000).Select(s => new
{
Date = DateTime.Now.AddHours(s * 4),
}));
int totalRecords = data.Count;
if (!string.IsNullOrWhiteSpace(gridSettings.SortColumn))
{
data = (gridSettings.SortOrder == "asc" ?
data.AsQueryable().OrderByPropertyName(gridSettings.SortColumn) :
data.AsQueryable().OrderByPropertyNameDescending(gridSettings.SortColumn)).ToArray();
}
data = data.Skip((gridSettings.PageIndex - 1) * gridSettings.PageSize).Take(gridSettings.PageSize).ToArray();
var jsonData = new
{
total = totalRecords / gridSettings.PageSize + 1,
page = gridSettings.PageIndex,
records = totalRecords,
rows = data
};
return Json(jsonData);
}
那么问题我应该如何与日期合作?如果我将它们保留为DateTime,它们将显示没有格式,但使用Date = DateTime.Now.AddHours(s * 4).ToString()
,不会排序正确吗?
答案 0 :(得分:1)
您可以在排序后格式化数据(我稍微重构了控制器操作以使其工作):
[HttpPost]
public JsonResult GetData(GridSettings gridSettings)
{
var data = Enumerable.Range(0, 1000).Select(s => DateTime.Now.AddHours(s * 4)).ToList();
var totalRecords = data.Count();
if (!string.IsNullOrWhiteSpace(gridSettings.SortColumn))
{
data = (gridSettings.SortOrder == "asc" ?
data.OrderBy(x=>x) :
data.OrderByDescending(x=>x)).ToList();
}
data = data.Skip((gridSettings.PageIndex - 1) * gridSettings.PageSize).Take(gridSettings.PageSize).ToList();
var id = (gridSettings.PageIndex - 1) * gridSettings.PageSize;
var jsonData = new
{
total = totalRecords / gridSettings.PageSize + 1,
page = gridSettings.PageIndex,
records = totalRecords,
rows = data.Select(d=>new
{
id = ++id,
Date = d.ToShortDateString()
})
};
return Json(jsonData);
}