我有一个包含ID列表的下拉列表。客户将选择一个,它将反映页面上的总价格。我正在创建一个ajax调用,当从Dropdown中提取不同的ID时,它会更新总数。
$("#BrandId").on('focus', function () {
// Store the current value on focus and on change
previous = this.value;
}).change(function () {
alert("Previous: " +previous);
sel = this.value;
alert("Selected: " +sel);
$.ajax({
cache: false,
type: "get",
contentType: "application/json; charset=utf-8",
url: '@Url.Action("GetBrandCost", "Shocks")',
data: JSON.stringify({ idp: previous, id: sel }),
dataType: "json",
aysnc: false,
success: function (data1) {
alert(data1);
//ShockTotal = $("#ShockTotal").html();
//ShockTotal = ShockTotal / 1;
////ShockTotal = ShockTotal - data1;
//$("#ShockTotal").html(data1);
}
});
});
警报工作正常,但是ajax没有将这些ID传递给控制器,控制器只是接收空值。
public decimal GetBrandCost(string idp, string id)
{
decimal costp = 0;
decimal cost = 0;
if (id == "" || id == null || idp == "" || idp == null)
{
return 0;
}
ShockBrand brandp = db.ShockBrands.Find(idp);
costp = brandp.Cost;
ShockBrand brand = db.ShockBrands.Find(id);
cost = brand.Cost;
cost = cost - costp;
return cost;
}
因为它们是null我正在命中我的if语句并且在成功中返回零。我阅读的大部分内容都是添加内容类型,但在我的情况下似乎没有帮助,我确定它有点小。
答案 0 :(得分:1)
从浏览器控制台,这个
$.ajax({
cache: false,
type: "get",
contentType: "application/json; charset=utf-8",
url: 'http://google.com',
data: JSON.stringify({ idp: 1, id: 2 }),
dataType: "json",
aysnc: false,
success: function (data1) {
console.log(data1)
}
});
将请求返回到http://google.com/?{%22idp%22:1,%22id%22:2}&_=1440696352799
,这是不正确的
并且没有stringify
$.ajax({
cache: false,
type: "get",
contentType: "application/json; charset=utf-8",
url: 'http://google.com',
data: { idp: 1, id: 2 },
dataType: "json",
aysnc: false,
success: function (data1) {
console.log(data1)
}
});
返回http://google.com/?idp=1&id=2&_=1440696381239
(请参阅网络标签)
所以不要使用JSON.stringify
为什么它会起作用 - 你的asp.net控制器动作接收简单的类型参数(字符串,数字等),jquery相当聪明,以确定将要发送什么,如果它是对象里面的对象它将它作为POST的POST数据发送给GET的对象的字符串表示(你有GET请求,但为了知识的目的,只需坚持可以发送的2种类型的数据, params & data )所以当jquery配置url时,asp.net会理解约定,并将请求与approciated action匹配
但是不要相信我,自己检查一下
chrome dev console是你的朋友
答案 1 :(得分:0)
你可以就像 var dataReq = {idp:previous,id:sel}; data:dataReq
并且无需使用dataType和contentType
答案 2 :(得分:0)
通过删除 contentType:“ application / json; charset = utf-8 和 dataType:“ json” 它为我工作。否则,我总是在控制器操作中得到value = null。 我现在用数据调用ajax的代码是:
links = ['site1', 'site2']
def main(links):
with requests.Session() as req:
for link in links:
r = req.get(link)
print(r.text)
main(links)