gpt4 book ai didi

c# - 部分 View 忽略数据集且不显示

转载 作者:太空狗 更新时间:2023-10-30 01:16:15 28 4
gpt4 key购买 nike

我正在 ASP.NET MVC 中开发应用程序。我正在处理一个页面,该页面接受一些用户输入的值,然后使用存储过程从中获取数据集。我的偏好是数据在显示的同一页面上输入,因此我使用 AJAX 和部分 View 来完成此操作。我的代码与一组虚拟的简单数据(简单字符串)完美配合,但现在我使用的是更高级的数据集(Ienumerable),它不再显示部分 View 。

这是我的部分观点(出于长度考虑,隐藏了输入数据的文本框):

<!--SEARCH RESULTS PARTIAL FILLED BELOW-->
<div id="search-results">

</div>
<!---->


<script>
function getSearchResults() {

var SqlViewModel = {
//assign textboxes to values to pass to controller (hidden)
}

$.ajax({
type: "POST",
data: JSON.stringify(SqlViewModel),
dataType: "json",
contentType: "application/json",
url: "/Sql/Search/",
success: function(result) {
$('#search-results').html(result);
}
}); }


</script>

我从文本框中获取数据,然后使用我的 ajax 将这些值传递到我的“搜索” Controller 方法。 (值都使用 SqlVieWModel 正确传递)

Controller 方法:

[HttpPost]
public ActionResult Search(SqlViewModel sT)
{
//code for stored procedure

var sql = //get stored procedure and parameters

SqlPartialViewModel obj = new SqlPartialViewModel();
obj.SqlData = sql; //obj.SqlData is of type IEnumerable<Get_Result>

return PartialView("_SearchResultsPartial", obj);

SqlPartialViewModel 定义:

 public class SqlPartialViewModel
{
public IEnumerable<Get_Result> SqlData { get; set; }
}

最后,我尝试简单地让这些数据显示在我的部分 View (_SearchResultssPartial.cshtml) 中:

 @model SqlPartialViewModel

<table>
<tr>
<th>//Display stuff</th>

</tr>
@foreach(var result in Model.SqlData)
{
<tr>
<td>//Display stuff</td>
</tr>
}

没有任何显示,我也没有收到任何错误。

最佳答案

在您的 Ajax 调用中,您期望来自服务器的 json 结果:

$.ajax({
type: "POST",
data: JSON.stringify(SqlViewModel),
dataType: "json", <---- HERE
contentType: "application/json",
url: "/Sql/Search/",
success: function(result) {
$('#search-results').html(result);
}
});

但是当您从 ActionResult 返回 PartialView 时,您返回的是 html 类型,而不是 json类型。

只需将 dataType 更改为 "html" 或删除该行(这样 javascript 将尝试自行解释)。

关于c# - 部分 View 忽略数据集且不显示,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35805690/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com