3

可能有一种更简单的方法可以做到这一点,如果有的话,我会全神贯注。我的情况是我在表单上有一个下拉列表,我成功地填充了文本和值。我还需要从客户端上可用的 db 表中的同一表行中获取其他相关字符串值,因此当用户从下拉列表中选择时,此相关数据将填充到表单上的文本框中。我只处理 4 条记录,因此存储在客户端上没什么大不了的。我考虑过通过 ViewData 将这些数据作为列表传递并加载到 javascript 数组中。当用户从下拉列表中选择时 - 我将确定所选索引并从数组中获取我需要的相关数据。我已经将下拉项的值用于其他所需数据,因此我需要一种方法来获取这些相关数据,而无需返回服务器。

谢谢,

麦克风

4

2 回答 2

7
var myArray = [
<% foreach (string item in ViewData["list"] as List<string>) { %>
"<%= item %>",
<% } %>
];

据报道,最后有一个逗号会在 IE 中中断,所以我建议使用视图扩展帮助器方法来使代码更易于管理:

<%= Html.JavaScriptArray(ViewData["list"] as List<string>, "myArray") %>

将此辅助方法放在您的解决方案中的某个位置:

public static string JavaScriptArray(this HtmlHelper htmlHelper, IList<string> values, string varName) {
    StringBuilder sb = new StringBuilder("var ");
    sb.append(varName);
    sb.append(" = [");
    for (int i = 0; i < values.Count; i++) {
        sb.append("'");
        sb.append(values[i]);
        sb.append("'");
        sb.append(i == values.Count - 1 ? "\n" : ",\n"); // Not the prettiest but it works...
    }
    sb.append("];");
    return sb.toString();
}

从技术上讲,扩展方法可以去任何地方,您只需要在 .aspx 文件中包含命名空间。实际上最好将它们保持在逻辑分离的类中,例如MyApp.Mvc.Extensions.JavaScriptExtensionsMyApp.Mvc.Extensions.LinkExtensions

于 2009-03-19T14:20:26.680 回答
1

怎么样...

<%= new System.Web.Script.Serialization.JavaScriptSerializer().Serialize(ViewData["list"]) %>
于 2009-03-20T05:59:32.047 回答