8

正如标题所说,我正在为该任务寻求一些帮助,我已经阅读了很多关于它的教程,但没有一个可以解决我的问题,即如何dropdownlistfor从数据库加载。到目前为止,我得到了以下代码:

**LNClientes():**

public List<ENDistrito> DistritoListar()
{
    return new ADClientes().DistritoListar();
}

**ADClientes():**

public List<ENDistrito> DistritoListar()
        {
            Database oDatabase =                      DatabaseFactory.CreateDatabase(ConfigurationManager.AppSettings["conexionBD"]);
            DbCommand odbcommand = oDatabase.GetStoredProcCommand("USP_SEL_DISTRITOS");

            List<ENDistrito> lista = new List<ENDistrito>();
            using (IDataReader reader = oDatabase.ExecuteReader(odbcommand))
            {
                while (reader.Read())
                    lista.Add(new ENDistrito(reader));
            }
            return lista;
        }

**Controller:**

 public ActionResult Registrar()
        {
            ViewBag.Message = Resources.Language.Title_Page_MC_C;
            var ListaDistrito = new LNClientes().DistritoListar();
            ViewBag.ObtenerDistrito = new SelectList(ListaDistrito, "IdDistrito", "DescripcionDistrito");
            return View();
        }

看法:

<div class="editor-field">
            @Html.EditorFor(model => model.DistritoCliente)
            @Html.DropDownListFor(model => model.DistritoCliente,(SelectList)ViewBag.ObtenerDistrito,"--Seleccione--")
            @Html.ValidationMessageFor(model => model.DistritoCliente)
        </div>

到目前为止一切正常,当我打开该表单dropdownlistfor时,当我提交表单时,我收到以下消息:

没有具有键“DistritoCliente”的“IEnumerable”类型的 ViewData 项。

关于我做错了什么或如何解决这个问题的任何想法。

提前致谢。

亚历克斯

4

2 回答 2

20

我通常如何构建我的下拉列表是这样的

@Html.DropDownListFor(x => x.Field, PathToController.GetDropDown())

然后在你的控制器中有一个像这样构建的方法

public static List<SelectListItem> GetDropDown()
    {
        List<SelectListItem> ls = new List<SelectListItem>();
        lm = (call database);
        foreach (var temp in lm)
        {
            ls.Add(new SelectListItem() { Text = temp.name, Value = temp.id });
        }
        return ls;
    }

希望它有所帮助。

于 2013-09-23T17:24:13.067 回答
4

控制器:

ViewBag.States = new SelectList(db.States, "StateID", "StateName");

View: (In your view write the code for dropdown like this)

@Html.DropDownListFor(m => m.Address.StateID,ViewBag.States as SelectList,"--Select State--")

--> 这里是我的数据库中的一个表中的地址,它的属性之一是 StateID

这对我来说非常有效.. 试试看!!

于 2015-02-17T08:55:01.757 回答