【发布时间】:2017-04-08 22:18:41
【问题描述】:
我可以使用这个从 MVC ASP.NET 传递一个变量:
var lastCategoryId = '<%=Model.CS.LastSelectedCategory %>';
这适用于字符串或整数,但如何处理字符串数组?我尝试以相同的方式传递数组,但变量设置为 System.String[] ?
【问题讨论】:
我可以使用这个从 MVC ASP.NET 传递一个变量:
var lastCategoryId = '<%=Model.CS.LastSelectedCategory %>';
这适用于字符串或整数,但如何处理字符串数组?我尝试以相同的方式传递数组,但变量设置为 System.String[] ?
【问题讨论】:
您可以通过这行简单的代码让 .NET 为您处理所有繁重的工作。
这假设您使用的是 MVC Razor 语法。
var yourJavaScriptArray = @Html.Raw(Json.Encode(Model.YourDotNetArray));
对于较新版本的 MVC,请使用:
var yourJavaScriptArray = @Html.Raw(Json.Serialize(Model.YourDotNetArray));
【讨论】:
Json.Encode() 不再适用于较新版本的 MVC。请改用Json.Serialize(Model.YourDotNetArray)。
你可以 JSON 序列化它。这种方式可以传递更复杂的值,而不必担心转义单引号、双引号等:
var categoriesList = <%= new JavaScriptSerializer().Serialize(new[] { "value1", "value2" }) %>;
编写一个 HTML 助手来做这件事会更好:
public static class HtmlExtensions
{
public static string JsonSerialize(this HtmlHelper htmlHelper, object value)
{
return new JavaScriptSerializer().Serialize(value);
}
}
然后在你看来:
<script type="text/javascript">
var categoriesList = <%= Html.JsonSerialize(new[] { "value1", "value2" }) %>;
</script>
【讨论】:
应该这样做
var someArray=[<%foreach (var s in myStringArray){%>'<%=s%>',<%}%>];
【讨论】:
类似这样的:
<script type="text/javascript">
var myArr = [<%=string.Join(",", strArr.Select(o => "\"" + o + "\"")) %>];
</script>
【讨论】:
o 包含引号怎么办?如果它包含双引号怎么办?如果它包含可能窃取您的身份验证 cookie 的 javascript 和 XSS 代码怎么办?甚至无法想象编写这样的代码可能造成的灾难。
一个班轮:
var data = [@Html.Raw(String.Join(",", Model.MyArray.Select(i => "'" + i + "'")))];
【讨论】:
使用 Json.NET
var yourlist = JSON.parse('@Html.Raw(JsonConvert.SerializeObject(Model.YourList))');
【讨论】:
您需要将数组格式化为 JavaScript 数组语法。
var someArray = [<%= Model.SomeArray.Select(x => "'" + x +"'")
.Aggregate((x,y) => x + ", " + y); %>];
这将用单引号将每个条目括起来,然后用方括号之间的逗号将它们连接在一起。
更新:删除了多余的括号。
【讨论】:
如此简单,如此简单
<script type="text/javascript">
var array = @Html.Raw(
Json.Encode(
(Model).Select(m=> new
{
id= m.ID,
name=m.Name
})
)
);
</script>
输出是:
[{"id":1,"name":"Name of 1"}, {"id":2,"name":"Name of 2"}, ...];
【讨论】:
只是想使用 Razor 语法提供答案:
我们有一个Dictionary<int, int>,我们正在为 jQuery Sparkline 渲染,以“数组数组”的形式。
var usageData = [ @string.Join(",", Model.UsageData.Select(d => string.Format("[{0},{1}]", d.Key, d.Value)).ToArray()) ];
这样使用:
$('#sparkline').UsageSparkline(usageData, { tooltipFormatter: cachedTooltips });
这是我们查看源代码时得到的:
var usageData = [ [-13,0],[-12,1],[-11,0],[-10,0],[-9,1],[-8,1],[-7,0],[-6,2],[-5,2],[-4,0],[-3,0],[-2,9],[-1,3],[0,4] ];
$('#sparkline').UsageSparkline(usageData, { tooltipFormatter: cachedTooltips });
【讨论】: