Setting the jsonp option to false now inhibits any url manipulation regarding the callback.
This commit is contained in:
parent
f74b844989
commit
158fa822de
|
@ -1,8 +1,7 @@
|
||||||
(function( jQuery ) {
|
(function( jQuery ) {
|
||||||
|
|
||||||
var jsc = jQuery.now(),
|
var jsc = jQuery.now(),
|
||||||
jsre = /(\=)(?:\?|%3F)(&|$)|()(?:\?\?|%3F%3F)()/i,
|
jsre = /(\=)(?:\?|%3F)(&|$)|()(?:\?\?|%3F%3F)()/i;
|
||||||
rquery_jsonp = /\?/;
|
|
||||||
|
|
||||||
// Default jsonp settings
|
// Default jsonp settings
|
||||||
jQuery.ajaxSetup({
|
jQuery.ajaxSetup({
|
||||||
|
@ -12,23 +11,36 @@ jQuery.ajaxSetup({
|
||||||
}
|
}
|
||||||
|
|
||||||
// Detect, normalize options and install callbacks for jsonp requests
|
// Detect, normalize options and install callbacks for jsonp requests
|
||||||
}).ajaxPrefilter("json jsonp", function(s, originalSettings) {
|
// (dataIsString is used internally)
|
||||||
|
}).ajaxPrefilter("json jsonp", function(s, originalSettings, dataIsString) {
|
||||||
|
|
||||||
|
dataIsString = ( typeof(s.data) === "string" );
|
||||||
|
|
||||||
if ( s.dataTypes[ 0 ] === "jsonp" ||
|
if ( s.dataTypes[ 0 ] === "jsonp" ||
|
||||||
originalSettings.jsonp ||
|
|
||||||
originalSettings.jsonpCallback ||
|
originalSettings.jsonpCallback ||
|
||||||
jsre.test(s.url) ||
|
originalSettings.jsonp != null ||
|
||||||
typeof(s.data) === "string" && jsre.test(s.data) ) {
|
s.jsonp !== false && ( jsre.test( s.url ) ||
|
||||||
|
dataIsString && jsre.test( s.data ) ) ) {
|
||||||
|
|
||||||
var responseContainer,
|
var responseContainer,
|
||||||
jsonpCallback = s.jsonpCallback =
|
jsonpCallback = s.jsonpCallback =
|
||||||
jQuery.isFunction( s.jsonpCallback ) ? s.jsonpCallback() : s.jsonpCallback,
|
jQuery.isFunction( s.jsonpCallback ) ? s.jsonpCallback() : s.jsonpCallback,
|
||||||
previous = window[ jsonpCallback ],
|
previous = window[ jsonpCallback ],
|
||||||
url = s.url.replace(jsre, "$1" + jsonpCallback + "$2"),
|
url = s.url,
|
||||||
data = s.url === url && typeof(s.data) === "string" ? s.data.replace(jsre, "$1" + jsonpCallback + "$2") : s.data;
|
data = s.data,
|
||||||
|
replace = "$1" + jsonpCallback + "$2";
|
||||||
|
|
||||||
if ( url === s.url && data === s.data ) {
|
if ( s.jsonp !== false ) {
|
||||||
url += (rquery_jsonp.test( url ) ? "&" : "?") + s.jsonp + "=" + jsonpCallback;
|
url = url.replace( jsre, replace );
|
||||||
|
if ( s.url === url ) {
|
||||||
|
if ( dataIsString ) {
|
||||||
|
data = data.replace( jsre, replace );
|
||||||
|
}
|
||||||
|
if ( s.data === data ) {
|
||||||
|
// Add callback manually
|
||||||
|
url += (/\?/.test( url ) ? "&" : "?") + s.jsonp + "=" + jsonpCallback;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
s.url = url;
|
s.url = url;
|
||||||
|
|
Loading…
Reference in a new issue