Показывать только формат даты и продолжать сортировку AZ в MVCContrib Grid - PullRequest
3 голосов
/ 13 марта 2012

Я использую следующий LINQ для создания модели сетки:

...
            var query = from a in GetUser()
                        select new UserModel
                        {
                            ID = a.ID,                            
                            StartDate = a.StartDate,
                            EndDate = a.EndDate,
                            StateName = a.State.StateName,
                            StateID = a.StateID,
                            City = a.City,
                        };
            return query;
  ....

и HTML-код

 @Html.Grid(Model.PagedList).Columns(
                        col =>
                        {
                            col.For(c => c.StateName).Named("State").Attributes(@class => "row").HeaderAttributes(@class => "head");
                            col.For(c => c.City).Named("City").Attributes(@class => "row").HeaderAttributes(@class => "head");
                            col.For(c => c.StartDate).Named("Start Date").Attributes(@class => "row").HeaderAttributes(@class => "head");
                            col.For(c => c.EndDate).Named("End Date").Attributes(@class => "row").HeaderAttributes(@class => "head");
                            col.For(c => Html.ActionLink("Details", "Details", new { id = c.ID })).Named("View Details").HeaderAttributes(@class => "head").DoNotEncode();
                        }).Sort(Model.GridSortOptions).Attributes(@class => "grid") 

Основная проблема заключается в том, как показать только DATE без части TIME?

Я пробовал некоторые варианты, но в некоторых случаях я получал ошибки, а в других случаях сортировка AZ вообще не работает.

Есть какая-нибудь подсказка?Спасибо !!!

Ответы [ 2 ]

4 голосов
/ 20 марта 2012

Попробуйте использовать

col
.For(c => c.EndDate.ToLongDateString())
.Named("End Date")
.Attributes(@class => "row")
.HeaderAttributes(@class => "head");
3 голосов
/ 02 декабря 2014

Что-то немного проще, я нахожу метод Формат в столбце. см. Документы здесь

Итак, ваш код выглядит примерно так:

col.For(c => c.EndDate).Format("{0:d"})
//use .Format("{0:yyyy-MM-dd}") to get 2014-10-21

Если вы хотите использовать ToShortDateString , вам необходимо определить имя столбца, а также имя столбца сортировки, например:

 col.For(c => c.EndDate.ToShortDateString())
    .Named("End Date")
    .SortColumnName("EndDate");
...