从 MVC 2 中的 ViewData 加载下拉列表
本文关键字:加载 下拉列表 ViewData 中的 MVC | 更新日期: 2023-09-27 18:36:27
>我有以下观点。这是我观点的全部代码
<asp:Content ID="Content2" ContentPlaceHolderID="HeadContent" runat="server">
<script src="http://code.jquery.com/jquery-1.9.1.js"></script>
<script src="http://code.jquery.com/ui/1.10.3/jquery-ui.js"></script>
</asp:Content>
<asp:Content ID="Content1" ContentPlaceHolderID="MainContent" runat="server">
<div>
<table>
<tr>
<td>
<select id="clientDDL">
</select>
<% Html.DropDownList("clientDDL",
new SelectList((IEnumerable)ViewData["Clients"], "Code", "Name")); %>
</td>
</tr>
</table>
</div>
</asp:Content>
我使用模型中的下一个视图数据:
public static List<lookup> GetClients()
{
using (ModelDataContext data = new ModelDataContext(System.Configuration.ConfigurationManager.ConnectionStrings["ConnectionString"].ToString()))
{
List<lookup> retVal = new List<lookup>();
List<Client> lClient = data.Clients.Where(a => a.IsActive == true).ToList();
lClient = lClient.OrderBy(o => o.ClientName).ToList();
foreach (Client item in lClient)
{
retVal.Add(new lookup() { Code = item.ClientID.ToString(), Name = item.ClientName, });
}
return retVal;
}
}
这是我的控制器:
public ActionResult ProcedureFilter()
{
ViewData["Clients"] = WorkflowModels.GetClients();
return View();
}
我错过了什么?我的下拉列表仍然为空。也许我必须做一些参考?请提出任何建议。
更新:问题是部分末尾的";"<%= %>。作品代码:
<%= Html.DropDownList("clientDDL",
new SelectList((IEnumerable)ViewData["Clients"], "Code", "Name")) %>
在您提供的 ASP.NET 代码中,使用相同的id
(cliendDDL)定义了 2 个 HTML select
标签(或下拉列表):
<select id="clientDDL"> <-- the first one
</select>
<% Html.DropDownList("clientDDL",
new SelectList((IEnumerable)ViewData["Clients"], "Code", "Name")); %> <-- the second one, Html.DropDownList generating a select under the hood.
是否有可能只显示第一个(空的),而第二个由于缺少字符而保持隐藏状态,从而将预期的HTML生成例程(Html.DropDownList
)更改为嵌入式代码块?
也许而不是:
<% Html.DropDownList
它应该是:
<%= Html.DropDownList or <%: Html.DropDownList
有关 <%:%> ASP.NET 4 语法,请参见此处
编辑
此外,不需要行尾字符的 ";",应将其删除。
查看页面:"<%=Html.DropDownList("Description", new SelectList(ViewData("Description")), "--Select--")%>"
托拉员:
函数 purchase() 作为操作结果:
Dim dataContext As New tblMVCDataContext
Dim teststr As String
Dim itemVar = From U In dataContext.Items Select U.Description
For Each tbItem In itemVar
teststr += tbItem + ","
Next
ViewData("Description") = teststr.Split(",")
Return View(itemVar)
End Function