Реализация меню выпадающего списка с динамическим содержимым в MVC3/4

Я использую MVC4 в первый раз. Я получил некоторые основы его логики.

Я хочу отобразить раскрывающийся список с некоторым динамическим содержимым (данные из базы данных).

Как я могу использовать модель, представление и контроллер для реализации этого? Пожалуйста, помогите мне с примером кода..


person myaseedk    schedule 28.07.2013    source источник


Ответы (2)


Это должно стать для вас хорошим началом.

Модели\ФуМодел.кс

public class FooModel
{
    public string Key { get; set; }
    public string Text { get; set; }
}

Модели\Фумоделлист.кс

public class FooModelList
{
    public int SelectedFooId { get; set; }
    public IEnumerable<FooModel> Foos { get; set; }
}

Контроллеры\Хомеконтроллер.кс

public class HomeController : Controller
{
    public ActionResult Index()
    {
        var model = new FooListModel
                        {
                            SelectedFooId = 0,
                            Foos = GetFooModels()
                        };

        return View(model);
    }

    [HttpPost]
    public ActionResult Index(FooListModel model)
    {
        if (ModelState.IsValid)
        {
            // do something with model
            return RedirectToAction("View", "Foo", new { Id = model.Key });
        }

        // somethings wrong.. 
        model.Foos = GetFooModels();
        return View(model);
    }

    private IEnumerable<FooModel> GetFooModels()
    {
        var dbContext = new FooDbContext();
        var fooModels = dbContext.Foos.Select(x =>
                            new FooModel
                            {
                                Key = x.Key,
                                Value = x.Value
                            };

        return fooModels.ToList();
    }
}

Виды\Home\Index.cshtml

@model MvcApp.Models.FooListModel
@{
    var fooList = new SelectList(Model.Foos, "Key", "Value");
}

@using (Html.BeginForm("DealSummaryComparison", "Reporting", FormMethod.Post)) {
    <div>
        Foos: @Html.DropDownListFor(x => x.SelectedFooId, fooList)
    </div>
    <div>
        <input type="submit" value="Submit" />
    </div>
}
person shuniar    schedule 01.08.2013

Подробности можно найти в этом сообщении. Поскольку вы только что получили базовые представления о MVC, в посте также есть базовый пример добавления выпадающего списка в MVC с использованием примеров баз данных NorthWind.

person R.C    schedule 28.07.2013