5

我成功地在插入时将值保存到数据库(标题值),但是当我在编辑模式下呈现相同的视图时,标题字段必须保存选定的值,但在我的情况下,标题下拉菜单没有选择任何值...不知道为什么我在标题字段保存存储值(在后端)时得到一个没有选择的下拉列表。

@Html.DropDownListFor(model => model.title, new SelectList(Model.titles, "Value", "Text"),"-Select-") // nothing selected on edit mode

 @Model.title //displaying the stored value which the user selected initially.


标题的值

titles = new SelectList(ListItem.getValues().ToList(), "Value", "Text").ToList();

获取值函数

 public static List<TextValue> getValues()
      {
    List<TextValue> titles= new List<TextValue>();
    TextValue T= new TextValue();


   T.Value = "Mr";
   T.Text = "Mr";
   titles.Add(T);

    T= new TextValue();
    T.Value = "Mrs";
    T.Text ="Mrs";
       titles.Add(T);

     T= new TextValue();
   T.Value = "Miss";
   T.Text = "Miss";
    titles.Add(T);

    T= new TextValue();
    T.Value ="Other";
   T.Text = "Other";
   titles.Add(T);


    return titles;

   }
4

2 回答 2

3

您必须使用 SelectList 的另一个 ctor

来自msdn

SelectList(IEnumerable, String, String, Object) 

使用列表的指定项、数据值字段、数据文本字段和选定值初始化 SelectList 类的新实例。

然后 :

@Html.DropDownListFor(model => model.title, 
                      new SelectList(Model.titles, "Value", "Text", Model.title),
                      "-Select-") 

顺便说一句,遵循基本标准通常是一个好主意(至少):您的属性应该以大写字符开头。

public string Title {get;set;}
于 2012-10-17T07:36:29.787 回答
0

意见:

    @Html.DropDownListFor(model => model.title, Model.titles, "-Select-")

控制器:

    Model.titles = new SelectList(ListItem.getValues(), "Value", "Text");

    public static List<SelectListItem> getValues()
    {
        List<SelectListItem> titles= new List<SelectListItem>();
        SelectListItem T= new SelectListItem();

        T.Value = "Mr";
        T.Text = "Mr";
        titles.Add(T);

        T = new SelectListItem();
        T.Value = "Mrs";
        T.Text = "Mrs";
        titles.Add(T);

        T = new SelectListItem();
        T.Value = "Miss";
        T.Text = "Miss";
        titles.Add(T);

        T = new SelectListItem();
        T.Value = "Other";
        T.Text = "Other";
        titles.Add(T);

        return titles;
    }

    public ActionResult Edit(int sno)
    {
        var model = db.table.SingleOrDefault(x => x.sno == sno);
        return View(model);
    }
于 2012-10-17T05:45:09.393 回答