У меня есть следующий вызов ajax, который отлично работает в Firefox и Chrome, но не в IE:
function getAJAXdates( startDate, numberOfNights, opts ) {
var month = startDate.getMonth() + 1;
var day = startDate.getDate();
var year = startDate.getFullYear();
var d = new Date();
var randNum = Math.floor(Math.random()*100000000);
$.ajax({
type : "GET",
dataType : "json",
url : "/availability/ajax/bookings?rand="+randNum,
cache : false,
data : 'month='+month+'&day='+day+'&year='+year+'&nights='+numberOfNights,
contentType : 'application/json; charset=utf8',
success : function(data) {
console.log('@data: '+data);
insertCellData(data, opts, startDate);
},
error:function(xhr, status, errorThrown) {
console.log('@Error: '+errorThrown);
console.log('@Status: '+status);
console.log('@Status Text: '+xhr.statusText);
}
});
}
Я точно знаю, что все переменные передают правильное содержимое, а $ .ajax действительно передает все параметры / значения.
Вот что я получаю по ошибке:
LOG: @Error: undefined
LOG: @Status: parsererror
LOG: @Status Text: OK
Мне известно о проблеме с кешем в IE, и для ее устранения был реализован случайный параметр.
Вот JSON, который я получаю (я могу видеть его, используя Чарльза)
{
"availability":[
{
"inventory_id":"5",
"booking_id":"21",
"start_date":"05-01-2010",
"number_nights":4,
"text":"deFrancisco, Martin - $500.00 ACTIVE",
"type":"BOOKING"
}
]
}
Наконец, это заголовки, которые отправляются обратно из серверной части:
header('Content-Type: application/json; charset=utf8');
header("Cache-Control: no-cache");
header("Expires: 0");
header('Access-Control-Max-Age: 3628800');
header('Access-Control-Allow-Methods: GET, POST, PUT, DELETE');
Есть идеи?