diff options
author | jeresig <jeresig@gmail.com> | 2010-01-23 16:51:51 -0500 |
---|---|---|
committer | jeresig <jeresig@gmail.com> | 2010-01-23 16:51:51 -0500 |
commit | 0912109ffc86610161c769534df84400ccd1aa65 (patch) | |
tree | 625f0814076bac82596d4e487cd12b77189b7a4d | |
parent | a6ef036bb6a3610431471eebc2623bf8ad06bdd6 (diff) | |
download | jquery-0912109ffc86610161c769534df84400ccd1aa65.tar.gz jquery-0912109ffc86610161c769534df84400ccd1aa65.zip |
Expose the JSON parsing logic. Fixes #5914.
-rw-r--r-- | src/ajax.js | 18 | ||||
-rw-r--r-- | src/core.js | 22 |
2 files changed, 23 insertions, 17 deletions
diff --git a/src/ajax.js b/src/ajax.js index 502f00653..552d412f4 100644 --- a/src/ajax.js +++ b/src/ajax.js @@ -591,23 +591,7 @@ jQuery.extend({ if ( typeof data === "string" ) { // Get the JavaScript object, if JSON is used. if ( type === "json" || !type && ct.indexOf("json") >= 0 ) { - // Make sure the incoming data is actual JSON - // Logic borrowed from http://json.org/json2.js - if (/^[\],:{}\s]*$/.test(data.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, "@") - .replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, "]") - .replace(/(?:^|:|,)(?:\s*\[)+/g, ""))) { - - // Try to use the native JSON parser first - if ( window.JSON && window.JSON.parse ) { - data = window.JSON.parse( data ); - - } else { - data = (new Function("return " + data))(); - } - - } else { - jQuery.error( "Invalid JSON: " + data ); - } + data = jQuery.parseJSON( data ); // If the type is "script", eval it in global context } else if ( type === "script" || !type && ct.indexOf("javascript") >= 0 ) { diff --git a/src/core.js b/src/core.js index 3ff95e020..5c9906888 100644 --- a/src/core.js +++ b/src/core.js @@ -470,6 +470,28 @@ jQuery.extend({ error: function( msg ) { throw msg; }, + + parseJSON: function( data ) { + // Make sure the incoming data is actual JSON + // Logic borrowed from http://json.org/json2.js + if (/^[\],:{}\s]*$/.test(data.replace(/\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, "@") + .replace(/"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, "]") + .replace(/(?:^|:|,)(?:\s*\[)+/g, ""))) { + + // Try to use the native JSON parser first + if ( window.JSON && window.JSON.parse ) { + data = window.JSON.parse( data ); + + } else { + data = (new Function("return " + data))(); + } + + } else { + jQuery.error( "Invalid JSON: " + data ); + } + + return data; + }, noop: function() {}, |