Tengo la siguiente llamada AJAX, que funciona perfectamente en Firefox y Chrome, pero no 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);
}
});
}
Sé que es un hecho de que toda la las variables pasan el contenido correcto y $ .ajax está de hecho pasando todos los parámetros/valores.
Esto es lo que me pasa en caso de error:
REGISTRO: @error: undefined REGISTRO: @status: parsererror REGISTRO: @status texto: OK
Estoy consciente del problema de caché IE e implementado un parámetro aleatorio para aclararlo.
Aquí es el JSON i regrese (soy capaz de verlo con Charles)
{
"availability":[
{
"inventory_id":"5",
"booking_id":"21",
"start_date":"05-01-2010",
"number_nights":4,
"text":"deFrancisco, Martin - $500.00 ACTIVE",
"type":"BOOKING"
}
]
}
Finalmente estos son los encabezados que se envían de vuelta desde el servidor:
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');
Cualquier ideas?
agregué contentType para ver si resuelve el problema pero no funciona incluso sin él. gracias – Sam3k