Так что я свободно следую учебнику Music Store. Я создал StoreManagerController на pg. 54ish. И он создал представление с помощью Create, Deleted, Edit и т. Д. Он сохраняет некоторые вещи в базу данных, а именно мои элементы управления EditFor, но больше ничего.
У меня есть несколько элементов управления DropDownListFor, заполненных обеими таблицами в базе данных, а также данными пользователя Active Directory. Я не уверен, как получить их, чтобы сохранить. Вот мой сокращенный код. Спасибо за помощь.
Вид:
<div class="createTopInner">
<div class="editor-label">
@Html.LabelFor(model => model.test.Category)
</div>
<div class="editor-field">
@Html.DropDownListFor(model => model.CategoryId, Model.CategoryItems, "")
@Html.ValidationMessageFor(model => model.test.Category)
</div>
</div>
Контроллер:
public ActionResult Create()
{
// These four lines get active directory users
ActiveDirectoryModel ads = new ActiveDirectoryModel();
ViewBag.assignedto = ads.FetchContacts();
ViewBag.coassignedto = ads.FetchContacts();
ViewBag.notifyto = ads.FetchContacts();
var model = Populate();
return View(model);
}
[HttpPost]
public ActionResult Create(CreateViewModel model)
{
if (ModelState.IsValid)
{
db.TestItems.AddObject(model.test);
db.SaveChanges();
return RedirectToAction("Index");
}
return View(model);
}
public CreateViewModel Populate()
{
var model = new CreateViewModel
{
CategoryItems =
from c in new IntraEntities().CategoryItems.ToList()
select new SelectListItem
{
Text = c.Name,
Value = c.ID.ToString()
}
};
return model;
}
Модель:
public class CreateViewModel
{
public Intra.Models.TestItem test{ get; set; }
public int CategoryId { get; set; }
public IEnumerable<SelectListItem> CategoryItems { get; set; }
}