当您执行return Json(...) 时,您是在明确告诉 MVC 不要使用视图,并提供序列化的 JSON 数据。您的浏览器会打开一个下载对话框,因为它不知道如何处理这些数据。
如果您想返回视图,只需像往常一样执行return View(...):
var dictionary = listLocation.ToDictionary(x => x.label, x => x.value);
return View(new { Values = listLocation });
然后在您的视图中,只需将您的数据编码为 JSON 并将其分配给 JavaScript 变量:
<script>
var values = @Html.Raw(Json.Encode(Model.Values));
</script>
编辑
这里有一个更完整的示例。由于我没有从您那里获得足够的上下文,因此此示例将假定一个控制器 Foo、一个动作 Bar 和一个视图模型 FooBarModel。此外,位置列表是硬编码的:
Controllers/FooController.cs
public class FooController : Controller
{
public ActionResult Bar()
{
var locations = new[]
{
new SelectListItem { Value = "US", Text = "United States" },
new SelectListItem { Value = "CA", Text = "Canada" },
new SelectListItem { Value = "MX", Text = "Mexico" },
};
var model = new FooBarModel
{
Locations = locations,
};
return View(model);
}
}
模型/FooBarModel.cs
public class FooBarModel
{
public IEnumerable<SelectListItem> Locations { get; set; }
}
Views/Foo/Bar.cshtml
@model MyApp.Models.FooBarModel
<script>
var locations = @Html.Raw(Json.Encode(Model.Locations));
</script>
从您的错误消息看来,您似乎在混合不兼容的类型(即Ported_LI.Models.Location 和MyApp.Models.Location),因此,回顾一下,确保从控制器操作端发送的类型与从控制器接收到的类型相匹配看法。特别是对于这个示例,控制器中的new FooBarModel 与视图中的@model MyApp.Models.FooBarModel 匹配。