所以我有一个基本形式,它接受一个地址,得到纬度/经度,然后我试图将lat / long值传递给我的API。 API正在获取变量但是在成功传递之后我的ajax调用中出现了解析错误。
<form method="GET">
<input id="address" type="text">
<button id='searchRadius' type="submit">Search</button>
</form>
ajax call
$('#searchRadius').on('click', function (e) {
var lati;
var lng;
var rad = 30;
var address = $('#address').val();
e.preventDefault();
$.ajax({
type: "GET",
url: "http://www.mapquestapi.com/geocoding/v1/address?key=LIhb6pFxB7qAlFC4Aiul9rM9i7R5BcgB&location=" + address,
beforeSend: function (xhr) {
xhr.setRequestHeader("Accept", "application/json");
xhr.setRequestHeader("Content-type", "application/json");
},
success: function postForm(response) {
lati = response.results[0].locations[0].latLng.lat;
lng = response.results[0].locations[0].latLng.lng;
console.log(lati, lng, rad);
$.ajax({
url: contextRoot + "/map/radius",
type: "GET",
data: {"lati": lati},
dataType: "json",
beforeSend: function (xhr) {
xhr.setRequestHeader("Accept", "application/json");
xhr.setRequestHeader("Content-type", "application/json");
},
success: function (data, status) {
console.log(data);
},
error: function (data, status) {
alert("bad api call");
console.log(status);
}
});
},
error: function (data, status) {
console.log(data.errors);
}}
);
});
api call
@RequestMapping(value = "/radius", method = RequestMethod.GET)
@ResponseBody
public String radiusSearch(HttpServletRequest request, Map model) {
String n1 = request.getParameter("lati");
return "redirect: /";
}
所以我得到参数“lati”但它不会重定向页面然后我在第二次ajax调用中得到一个错误。在传递变量之前,我是否需要JSON.Stringify变量?我确实需要将变量“lati”,“lng”,“rad”传递给api,但我试图让它首先使用它。
答案 0 :(得分:0)
当您使用Ajax时,Spring控制器会假设返回text,String或json。为什么呢?
因为您的Ajax成功方法需要接收text,String或json。
这意味着您无法像Ajax响应一样执行重定向。
因此,如果您想要返回lati
变量的文本,请执行以下操作:
@RequestMapping(value = "/radius", method = RequestMethod.GET)
@ResponseBody
public String radiusSearch(HttpServletRequest request, Map model) {
String n1 = request.getParameter("lati");
return n1;
}
如果你想返回一些参数,那么是的,json是一个很好的选择。
你可以使用jackson-databind jar轻松完成,你需要做的就是返回一个包含这三个变量的对象,当然你需要在你的控制器上使用@ResponseBody
注释
还有一件事,在您的客户端Ajax调用您需要标记您希望接收json类型。 datatype: "json"
,就像这样:
$.ajax({
type: "GET",
url: "http://www.mapquestapi.com/geocoding/v1/address?
datatype: "json"
key=LIhb6pFxB7qAlFC4Aiul9rM9i7R5BcgB&location=" + address,
beforeSend: function (xhr) {
xhr.setRequestHeader("Accept", "application/json");
xhr.setRequestHeader("Content-type", "application/json");
},
success: function postForm(response) {
lati = response.results[0].locations[0].latLng.lat;
lng = response.results[0].locations[0].latLng.lng;
console.log(lati, lng, rad);
});