ASP.Net Core 5 MVC Заполняет выпадающий список записями базы данных

#c# #asp.net-mvc #asp.net-core #drop-down-menu

Вопрос:

В названии указано, что я пытаюсь сделать.

Способ управления:

 public IActionResult Create()
        {
            IEnumerable<string> hList = from char s in _context.NR_Users select s.ToString();

            List < NR_User > hUsers = new List<NR_User>();
            hUsers = (from c in _context.NR_Users select c).ToList();
            hUsers.Insert(0, new NR_User { ID = 0, Name = "Select" });
            ViewBag.historyUsers = hUsers;

            List<SelectListItem> options = new()
            {
                new SelectListItem { Value = "True", Text = "Yes" },
                new SelectListItem { Value = "False", Text = "No" }
            };
            ViewBag.options = options;
            return View();
        }
 

Вид:

 <div class="form-group col-md-4">
                    <label class="control-label">History PM</label>
                    <select asp-for="History_PM" name="History_PM" class="form-control" asp-items="@ViewBag.historyUsers"></select>
                    <span asp-validation-for="History_PM" class="text-danger"></span>
                </div>
 

Но когда я запускаю приложение и перехожу на страницу Создания, я получаю эту ошибку:

 RuntimeBinderException: Cannot implicitly convert type 'System.Collections.Generic.List<EnvApp.Models.DB.NR_User>' to 'System.Collections.Generic.IEnumerable<Microsoft.AspNetCore.Mvc.Rendering.SelectListItem>'. An explicit conversion exists (are you missing a cast?)
 

Я понимаю, что он не может неявно преобразовать список в IEnumerable, но как именно это сделать?

Ответ №1:

Вы можете преобразовать список с помощью класса SelectList.

Попробуйте заменить

 <select asp-for="History_PM" name="History_PM" class="form-control" asp-items="@ViewBag.historyUsers"></select>
 

с

 <select asp-for="History_PM" name="History_PM" class="form-control" asp-items="@(new SelectList(ViewBag.historyUsers, "ID", "Name"))"></select>
 

Комментарии:

1. Вот и все, спасибо тебе огромное, парень, о котором я и понятия не имел!