当你这样做时,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
。此外,位置列表是硬编码的:
控制器/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; }
}
视图/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
视图。