我有一个包含各种行的表,每行对应一个ID。对于每一行,我都有EDIT选项,选中此选项后,用户可以在“ Edit.chtml ”字段中查看与该ID对应的默认值,并通过删除默认值进行更新并输入新条目并保存。
在' Edit.chtml '中,我有一个“MANAGERS”字段,我需要填充一个名称下拉列表,其中显示的默认值/选定值对应于编辑行的ID从表中选择操作。 我正在使用viewBag,但我的问题是下拉列表始终显示列表中的第一项而不是选定的值。请参阅下面的代码。
Controller:
//
// GET: /ManagersNAMES/Edit/5
public ActionResult Edit(int id)
{
using (var db = new InpEntities())
{
var list_managers = (from x in db.TABLE_MANAGERS
select new TABLE_MANAGERSDTO
{
ID = x.ID,
NAME = x.NAME,
}).OrderBy(w => w.NAME).ToList();
ViewBag.managers = new SelectList(list_managers, "ID", "NAME", id);
return View();
}
}
public class TABLE_MANAGERSDTO
{
public string NAME { get; set; }
public int ID { get; set; }
}
//
// POST: /ManagersNAMES/Edit/5
[HttpPost]
public ActionResult Edit(int id, TABLE_INSTITUTES dp)
{
try
{
using (var db = new InpEntities())
{
TABLE_INSTITUTES tmp = (TABLE_INSTITUTES)db.TABLE_INSTITUTES.Where(f => f.ID == id).First();
tmp.MANAGER = dp.MANAGER;
db.SaveChanges();
return RedirectToAction("Index");
}
}
catch
{
return View();
}
}
查看:' Edit.chtml '
@{
ViewBag.Title = "Edit";
}
<h2>Edit</h2>
@using (Html.BeginForm())
{
@Html.ValidationSummary(true)
<fieldset>
<div class="editor-label" style="font-weight:bold">MANAGER</div>
<div class="editor-field">
@Html.DropDownList("dp.MANAGER", (SelectList)ViewBag.managers)
</div>
<p>
<input type="submit" value="Save" />
</p>
</fieldset>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
答案 0 :(得分:2)
您需要在控制器中设置所选的ID,如下所示:
var list_managers = list_managers.Select(x => new
{
Value = x.ID.ToString(),
Text = x.Name
})
.ToList();
ViewBag.managers = new SelectList(list_managers, "ID", "NAME", id);
并将您的观点更改为:
@Html.DropDownList("dpMANAGER", (SelectList)ViewBag.managers)
答案 1 :(得分:2)
刚写了@Html.DropDownList("dp.MANAGER", ViewBag.managers)
没有选择列表,因为它已经是SelectList的类型。
然后像这样写ViewBag.managers = new SelectList(list_managers, "ID", "NAME");