我有一个包含if语句的控制器,但如果它遇到第一个或第二个块则不重要,因为它们都返回相同的Type。
[HttpPost]
public ActionResult Descriptions(string partsNo, Details searchValue)
{
var response = partsNo != null ? _referenceRepository.GetParts(partsNo) : _referenceRepository.SearchValue(searchValue);
return PartialView(response);
}
查看
@model ArrowEngineeringMVC.Models.Details
<script>
$(document)
.on("click",
".getPartNo",
function (e) {
var val = $(this).val();
$.ajax({
url: '/Home/Descriptions',
contentType: 'application/json',
type: 'POST',
data: JSON.stringify({ "partsNo": val }),
dataType: 'html'
})
.success(function (result) {
$('#descriptionPlace').html(result);
})
.error(function (xhr, status) {
alert(status);
});
})
</script>
@using (Html.BeginForm("Descriptions", "Home", FormMethod.Post))
{
<div class="topBar">
@Html.TextBoxFor(m => m.Type)
<input type="submit" id="submitId" value="submit"/>
</div>
}
<div class="leftPanel">
<button href="javascript:void(0)" id="NumbersButton" value="Number" class="getPartNo">#</button>
<button href="javascript:void(0)" value="A" class="getPartNo">A</button>
<button href="javascript:void(0)" value="B" class="getPartNo">B</button>
<button href="javascript:void(0)" value="C" class="getPartNo">C</button>
</div>
<div id="descriptionPlace"></div>
如果单击其中一个按钮,它将触及if语句的第一部分。如果你这样做,那么返回一个PartialView并且一切正常,按钮的值将使用AJAX传递给控制器,而如果你进行搜索,它将通过模型传递,这是唯一的区别。
如果你进行搜索,它会触及if语句的第二部分而不返回部分视图,它只会因某种原因返回一个新视图。
我只是感到困惑,因为变量响应会返回一个List但只包含不同的值,具体取决于您点击的if语句的哪个部分。
继承了 referenceRepository ,只是为了让它更容易理解:
public List<Parts> SearchValue(Details searchValue)
{
const string detailsSql = "SELECT [ID], [Description] FROM Table1 WHERE [Type] = {0}";
string queryDetails = string.Format(detailsSql, searchValue.Type);
var dbDetails = getConnection().Query<Parts>(queryDetails).ToList();
return dbDetails;
}
public List<Parts> GetParts(string partNumber)
{
string partsSql;
if (partNumber == "Number")
{
partsSql = "SELECT [ID], [Description] FROM Table1 WHERE [Part Number] not like '%[^0-9]%'";
}
else
{
partsSql = "SELECT [ID], [Description] FROM Table1 WHERE [Part Number] like '{0}%'";
}
string queryParts = string.Format(partsSql, partNumber);
var dbParts = getConnection().Query<Parts>(queryParts).ToList();
return dbParts;
}
答案 0 :(得分:0)
如果您希望在提交点击时在#descriptionPlace div中获得与部分视图相同的结果。那么您可以尝试这样删除表单标签。并将提交按钮的click事件与这些getnumbers按钮绑定..
不需要发布一个值?我是对的吗?
如果你想具体要在div或特定区域加载局部视图,那么你必须提到像ajax call.or你可以使用@ Html.Partial或RenderPartial.But你的要求有点奇怪。所以你可以尝试这样..