我的目标是限制来自其他表的数据的某些输入,因此我试图通过ajax调用来完成它。
这是控制器:
[HttpPost]
public JsonResult getProductbyId(string data)
{
int id = Convert.ToInt32(data);
tblProducto producto = db.tblProducto.Where(p => p.Id == id).SingleOrDefault();
return Json(producto);
}
这是ajax调用
var id_producto = $('#id_producto option:selected').val();
$.ajax({
url: '/Ventas/getProductbyId',
type: 'post',
data: { data:id_producto },
success: function (data) {
alert(data.cantidad);
},
error: function (data) {
alert('La llamada (ajax)getProductbyId ha fallado');
}
});
但是我收到错误警报。
尝试:在控制器中更改返回格式
在Contoller中:
[HttpPost]
public JsonResult getProductbyId(string data)
{
int id = Convert.ToInt32(data);
tblProducto producto = db.tblProducto.Where(p => p.Id == id).SingleOrDefault();
return Json(producto, JsonRequestBehavior.AllowGet);
}
在Jquery中(ajax调用):
var id_producto = $('#id_producto option:selected').val();
$.ajax({
url: '/Ventas/getProductbyId',
type: 'post',
dataType: "JSON",
data: { data:id_producto },
processData: false,
contentType: false,
success: function (data) {
alert(data);
},
error: function (data) {
alert('La llamada (ajax)getProductbyId ha fallado');
}
});