通过更新字段删除值

时间:2014-09-20 23:03:21

标签: asp.net-mvc-4 visual-studio-2012 c#-5.0

我有这个:

查看:

@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的意思不正确?因为你没有无限的自行车标记列表。所以这就是为什么我选择制作一个包含所有标记,颜色和大小的下拉列表。因为管理员填写标记,大小等,然后用户可以选择标记,颜色等。但是你将如何设计不同的属性?

我没有颜色,标记等的单独表格。但这是必要的吗?

谢谢

1 个答案:

答案 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