// implement the XMLHttpRequest in IE7 (can't request local files),
// so we use the ActiveXObject when it is available
// This function can be overriden by calling jQuery.ajaxSetup
- xhr: function() {
- if ( window.XMLHttpRequest && (window.location.protocol !== "file:" || !window.ActiveXObject) ) {
+ xhr: window.XMLHttpRequest && (window.location.protocol !== "file:" || !window.ActiveXObject) ?
+ function() {
return new window.XMLHttpRequest();
-
- } else {
+ } :
+ function() {
try {
return new window.ActiveXObject("Microsoft.XMLHTTP");
} catch(e) {}
- }
- },
+ },
accepts: {
xml: "application/xml, text/xml",
html: "text/html",
},
httpData: function( xhr, type, s ) {
- var ct = xhr.getResponseHeader("content-type"),
- xml = type === "xml" || !type && ct && ct.indexOf("xml") >= 0,
+ var ct = xhr.getResponseHeader("content-type") || "",
+ xml = type === "xml" || !type && ct.indexOf("xml") >= 0,
data = xml ? xhr.responseXML : xhr.responseText;
if ( xml && data.documentElement.nodeName === "parsererror" ) {
// The filter can actually parse the response
if ( typeof data === "string" ) {
-
// If the type is "script", eval it in global context
- if ( type === "script" ) {
+ if ( type === "script" || !type && ct.indexOf("javascript") >= 0 ) {
jQuery.globalEval( data );
}
// Get the JavaScript object, if JSON is used.
- if ( type === "json" ) {
- if ( typeof JSON === "object" && JSON.parse ) {
+ if ( type === "json" || !type && ct.indexOf("json") >= 0 ) {
+ // Try to use the native JSON parser first
+ try {
data = JSON.parse( data );
- } else {
+
+ } catch(e) {
data = (new Function("return " + data))();
}
}