Use a different workaround for detecting when Opera finds a status 304 page. Fixes #6060.

This commit is contained in:
John Resig 2010-09-21 15:22:34 -04:00
parent 3a0a352883
commit ba9e0fc177
3 changed files with 18 additions and 3 deletions

View file

@ -629,9 +629,11 @@ jQuery.extend( jQuery.ajax, {
try { try {
// IE error sometimes returns 1223 when it should be 204 so treat it as success, see #1450 // IE error sometimes returns 1223 when it should be 204 so treat it as success, see #1450
return !xhr.status && location.protocol === "file:" || return !xhr.status && location.protocol === "file:" ||
// Opera returns 0 when status is 304
( xhr.status >= 200 && xhr.status < 300 ) || ( xhr.status >= 200 && xhr.status < 300 ) ||
xhr.status === 304 || xhr.status === 1223 || xhr.status === 0; xhr.status === 304 || xhr.status === 1223 ||
// Opera returns a status of 0 for redirects -
// We can detect this by the fact that Opera also doesn't return any headers
xhr.status === 0 && !xhr.getAllResponseHeaders();
} catch(e) {} } catch(e) {}
return false; return false;
@ -651,7 +653,7 @@ jQuery.extend( jQuery.ajax, {
} }
// Opera returns 0 when status is 304 // Opera returns 0 when status is 304
return xhr.status === 304 || xhr.status === 0; return xhr.status === 304 || xhr.status === 0 && !xhr.getAllResponseHeaders();
}, },
httpData: function( xhr, type, s ) { httpData: function( xhr, type, s ) {

View file

@ -0,0 +1 @@
<?php header('HTTP/1.0 304 Not Modified'); exit; ?>

View file

@ -68,6 +68,18 @@ test("jQuery.ajax() - error callbacks", function() {
}); });
}); });
test(".ajax() - 304", function() {
expect( 1 );
stop();
jQuery.ajax({
url: url("data/notmodified.php"),
success: function(){ ok(true, "304 ok"); },
error: function(){ ok(false, "304 not ok "); },
complete: function(xhr){ start(); }
});
});
test(".load()) - 404 error callbacks", function() { test(".load()) - 404 error callbacks", function() {
expect( 6 ); expect( 6 );
stop(); stop();