我有这个:
查看:
@using (Html.BeginForm())
{
@Html.AntiForgeryToken()
<div class="form-horizontal">
<h4>Bycicle</h4>
<hr />
@Html.ValidationSummary(true)
@Html.HiddenFor(model => model.id)
<div class="form-group">
<label class="control-label col-md-2" for="BycicleID">Mark</label>
<div class="col-md-10">
@Html.DropDownList("BycicleID", String.Empty)
@Html.ValidationMessageFor(model => model.id)
</div>
</div>
控制器:
public async Task<ActionResult> Edit(int? id)
{
if (id == null)
{
return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
}
Bycicle bycicle = await db.Bycicles.FindAsync(id);
if (bycicle == null)
{
return HttpNotFound();
}
ViewBag.id = new SelectList(db.Bycicles, "BycicleID", "Mark", bycicle.id);
//ViewBag.Color = new SelectList(db.Bycicles, "Color", "Color", bycicle.Color);
//ViewBag.Weight = new SelectList(db.Bycicles, "Weight", "Weight", bycicle.Weight);
//ViewBag.Height = new SelectList(db.Bycicles, "Height", "Height", bycicle.Height);
return View(bycicle);
}
// POST: Bycicle/Edit/5
[HttpPost]
[ValidateAntiForgeryToken]
public async Task<ActionResult> Edit(
[Bind(Include = "id, Mark, Color, Weight,Height")]
Bycicle bycicle)
{
if (ModelState.IsValid )
{
db.Entry(bycicle).State = EntityState.Modified;
await db.SaveChangesAsync();
return RedirectToAction("Index");
}
ViewBag.id = new SelectList(db.Bycicles, "id", "Mark", bycicle.id);
return View(bycicle);
}
和模型:
public class Bycicle
{
public int id { get; set; }
// [Column("Mark")]
public string Mark { get; set; }
public string Color { get; set; }
public string Weight { get; set; }
public string Height { get; set; }
public DateTime? LastTimeChecked { get; set; }
}
但是我可以更新其他值(颜色,重量,高度)但是如果我在更新视图中按保存,则会删除标记名称。我还检查了数据库,更新后标记值消失了。但是,如果我只按下编辑(更新)然后首先我在下拉列表中看到值(标记),但保存后标记值消失了。即使我没有在更新视图中更改标记值。
我只是想知道出了什么问题。
谢谢!
Oke,
我明白这是一个类型错误,
但你对dropdonlists的意思不正确?因为你没有无限的自行车标记列表。所以这就是为什么我选择制作一个包含所有标记,颜色和大小的下拉列表。因为管理员填写标记,大小等,然后用户可以选择标记,颜色等。但是你将如何设计不同的属性?
我没有颜色,标记等的单独表格。但这是必要的吗?
谢谢
答案 0 :(得分:0)
您没有绑定任何属性Mark
(您显示的内容绑定到ID
属性)。优选地,您的选择列表的名称不应与您的属性相同。
在控制器中
ViewBag.MarkList = new SelectList(db.Bycicles, "BycicleID", "Mark");
并在视图中
@model YourAssembly.Bycicle
....
<div class="form-group">
@Html.LabelFor(m => m.Mark)
<div class="col-md-10">
@Html.DropDownListFor(m => m.Mark, (SelectList)ViewBag.MarkList)
@Html.ValidationMessageFor(m => m.Mark)
</div>
</div>
注意,由于您绑定了所有属性,因此不需要[Bind(Include = "id, Mark, Color, Weight,Height")]
修改强>
虽然通过ViewBag
传递值,但我建议您使用视图模型和强类型帮助程序,这样您就可以获得智能感知支持以及使用视图模型的所有其他好处。
public class BycicleVM
{
public int id { get; set; }
// other properties of Bycicle that you want to edit
public SelectList MarkList { get; set; }
// other select lists
}
然后将选择列表分配给视图模型而不是ViewBag