多个ajax请求的情况下,有时候我们需要使这些请求变成同步的 (如,for循环下发送请求,为了使响应结果不乱序,需要请求同步执行), 这个时候需要考虑一个问题:请求是否跨域执行。
(1) 如果不是跨域访问,那么一般可以通过设置ajax请求的属性即可同步请求 ;
//设置ajax请求为同步进行
$.ajaxSettings.async=false;//遍历车辆数据表单
for(var j=0;j<carData.cars.length;j++){
//找到被id选中的车辆信息
if(carData.cars[j].id==idIndex){
//根据车辆的sn号 查找 相应的gps坐标点
var device_sn=carData.cars[j].sn;
$.get("api.action?/device.get.do?device_sn="+device_sn,function(gpsData){
//显示定义二维数组,记录被勾选的车辆信息及其gps经纬度
selectedCars[index]=new Array(2);
selectedCars[index][0]=carData.cars[j].number;
selectedCars[index][1]=gpsData.device.position.lng+","+gpsData.device.position.lat;
index++;
});
}
}
//恢复ajax请求为异步进行
$.ajaxSettings.async=true;
(2) 如果是跨域访问,那么这种直接设置ajax属性的方式是失效的,跨域时使用jsonp格式,jquery的官方在线文档声明,用jsonp实现跨域,
只能使用异步提交,无论你是否设置async;
- $.getJSON(" http://www.kuayu.com/demo.do?name1="+value1+"&callback=?",
- function(json){
- if(json.属性名==值){
- // 执行代码
- }
- });