这是我的HTML
<ul class="sb_dropdown" style="display:none;">
<li class="sb_filter">Chon the loai</li>
<li><input type="checkbox" value="All"/><label for="all"><strong>Tất cả</strong></label></li>
<li><input type="checkbox" value="Woman"/><label for="Automotive">Đồ nữ</label></li>
<li><input type="checkbox" value="Shoes"/><label for="Baby">Giày</label></li>
<li><input type="checkbox" value="Bag"/><label for="Beauty">Túi sách</label></li>
<li><input type="checkbox" value="Man"/><label for="Books">Đồ nam</label></li>
</ul>
这是我调用控件的ajax,
<script>
$('.sb_search').click(function () {
var list = [];
$('ul.sb_dropdown').find("input:checkbox:checked").each(function () {
list.push($(this).val());
});
var key = { listkey: list };
$.ajax({
url: '@Url.Action("Search", "Result")',
traditional: true,
data: list,
dataType: "html",
type: 'POST',
success: function (data) {
alert("success");
},
error: function () {
alert("fail");
}
});
});
</script>
在我的控制器中,我有一个参数列表键,我希望当我点击按钮搜索时会从视图中收到
public ActionResult Result()
{
return View();
}
[HttpPost]
public ActionResult Result(List<string> listkey)
{
var n = listkey;
return View();
}
当我调试这个没有做动作结果,它警告失败。告诉我什么我做错了。请帮助我关于returnjson为什么我需要使用而不是我想使用普通视图来显示我结果
我已经解决了这个问题,因为我在我的ajax中放错了动作和控制器。谢谢大家
答案 0 :(得分:3)
编辑试试这个,创建数组并将其传递给控制器
var stringArray = new Array();
stringArray[0] = "item1";
stringArray[1] = "item2";
stringArray[2] = "item3";
var postData = { listkey: stringArray };
比你的数据还要多,在你的ajax调用中
data: postData
$.ajax({
type: "POST",
url: '@Url.Action("Search", "Result")',
data: postData,
success: function(data){
alert(data.Result);
},
dataType: "json",
traditional: true
});
你可以这样做,
您的数据将为data: '{ "listkey":' + JSON.stringify(list) + '}',
$.ajax({
url: '@Url.Action("Search", "Result")',
traditional: true,
data: '{ "listkey":' + JSON.stringify(list) + '}',
dataType: "html",
type: 'POST',
success: function (data) {
alert("success");
},
error: function () {
alert("fail");
}
});
而不是试图看到你得到你想要的结果
[HttpPost]
public ActionResult Result(List<string> listkey)
{
var n = listkey;
return View();
}
答案 1 :(得分:0)
<script>
$('.sb_search').click(function () {
var list = [];
$('ul.sb_dropdown').find("input:checkbox:checked").each(function () {
list.push($(this).val());
});
$.ajax({
url: '@Url.Action("Search", "Result")',
data: { listkey: list },
dataType: "json",
type: 'POST',
traditional: true,
success: function (data) {
alert("success");
},
error: function () {
alert("fail");
}
});
});
</script>
[HttpPost]
public ActionResult Result(List<string> listkey)
{
var n = listkey;
return View();
}