Сортировка вложенных коллекций с помощью EditorFor

Я использую шаблоны общего редактора для отображения вложенных коллекций в моем представлении с помощью HTML-помощника «EditorFor», аналогичного следующему. Я не в восторге от всех этих вложенных частичных представлений, но, делая это таким образом, правильно называю элементы, чтобы они без проблем отправлялись обратно в мой контроллер в ViewModel.

Как бы я отсортировал порядок на самом решительном уровне гнезда? В этом случае, как мне заставить «Budget.vbhtml» отображаться в порядке Года (по убыванию)?

Заранее спасибо!

Представление верхнего уровня (Organization.vbhtml):

<div id="budgets">
     @Html.EditorFor(Function(org) org.OrganizationBudgets))
</div>

ОрганизацияБюджет.vbhtml:

@ModelType CharityMVC.OrganizationBudget
@Html.EditorFor(Function(ob) ob.Budget)

Бюджет.vbhtml:

@ModelType CharityMVC.Budget
@Model.Year @Html.EditorFor(Function(b) b.Amount)

ОБНОВИТЬ:

Похоже, я должен делать это в своем контроллере, когда я заполняю свой объект модели, но как мне отсортировать дочерние элементы или дочерние элементы в запросе linq? Это мой текущий код:

Function Edit(ByVal id As Integer) As ActionResult
    Dim o As Organization
    Dim ovm As OrganizationViewModel

    'Load the organization from the database
    o = (From org In _db.Organizations _
        Where org.Id = id _
        Select org).FirstOrDefault()

    'Map it to the ViewModel
    ovm = AutoMapper.Mapper.Map(Of Organization, OrganizationViewModel)(o)

    Return View(ovm)

End Function

person Ben Finkel    schedule 26.05.2011    source источник
comment
Пара мыслей, которые у меня были, но я не уверен, как их реализовать: используйте DataAnnotations для указания порядка сортировки. Примените сортировку в Automapper, которая сопоставляется с моей ViewModel.   -  person Ben Finkel    schedule 26.05.2011


Ответы (1)


Мой лучший ответ на данный момент:

Несколько запросов LINQ, заполняющих дочерние свойства, например:

Function Edit(ByVal id As Integer) As ActionResult
    Dim o As Organization
    Dim ovm As OrganizationViewModel

    'Load the organization from the database
    o = (From org In _db.Organizations _
        Where org.Id = id _
        Select org).FirstOrDefault()

    o.OrganizationBudgets = (From ob In _db.OrganizationBudgets _
                             Where ob.OrganizationId = o.Id _
                             Order By ob.Budget.Year Descending _
                             Select ob).ToList()


    'Map it to the ViewModel
    ovm = AutoMapper.Mapper.Map(Of Organization, OrganizationViewModel)(o)

    Return View(ovm)

End Function
person Ben Finkel    schedule 26.05.2011