3
* version: 2.3 (2011-09-17)
5
* This document is licensed as free software under the terms of the
6
* MIT License: http://www.opensource.org/licenses/mit-license.php
8
* Brantley Harris wrote this plugin. It is based somewhat on the JSON.org
9
* website's http://www.json.org/json2.js, which proclaims:
10
* "NO WARRANTY EXPRESSED OR IMPLIED. USE AT YOUR OWN RISK.", a sentiment that
13
* It is also influenced heavily by MochiKit's serializeJSON, which is
14
* copyrighted 2005 by Bob Ippolito.
19
var escapeable = /["\\\x00-\x1f\x7f-\x9f]/g,
32
* Converts the given argument into a JSON respresentation.
34
* @param o {Mixed} The json-serializble *thing* to be converted
36
* If an object has a toJSON prototype, that will be used to get the representation.
37
* Non-integer/string keys are skipped in the object, as are keys that point to a
41
$.toJSON = typeof JSON === 'object' && JSON.stringify
51
if ( type === 'undefined' ) {
54
if ( type === 'number' || type === 'boolean' ) {
57
if ( type === 'string') {
58
return $.quoteString( o );
60
if ( type === 'object' ) {
61
if ( typeof o.toJSON === 'function' ) {
62
return $.toJSON( o.toJSON() );
64
if ( o.constructor === Date ) {
65
var month = o.getUTCMonth() + 1,
67
year = o.getUTCFullYear(),
68
hours = o.getUTCHours(),
69
minutes = o.getUTCMinutes(),
70
seconds = o.getUTCSeconds(),
71
milli = o.getUTCMilliseconds();
83
minutes = '0' + minutes;
86
seconds = '0' + seconds;
94
return '"' + year + '-' + month + '-' + day + 'T' +
95
hours + ':' + minutes + ':' + seconds +
98
if ( o.constructor === Array ) {
100
for ( var i = 0; i < o.length; i++ ) {
101
ret.push( $.toJSON( o[i] ) || 'null' );
103
return '[' + ret.join(',') + ']';
110
if ( type === 'number' ) {
111
name = '"' + k + '"';
112
} else if (type === 'string') {
113
name = $.quoteString(k);
115
// Keys must be numerical or string. Skip others
120
if ( type === 'function' || type === 'undefined' ) {
121
// Invalid values like these return undefined
122
// from toJSON, however those object members
123
// shouldn't be included in the JSON string at all.
126
val = $.toJSON( o[k] );
127
pairs.push( name + ':' + val );
129
return '{' + pairs.join( ',' ) + '}';
135
* Evaluates a given piece of json source.
137
* @param src {String}
139
$.evalJSON = typeof JSON === 'object' && JSON.parse
142
return eval('(' + src + ')');
146
* jQuery.secureEvalJSON
147
* Evals JSON in a way that is *more* secure.
149
* @param src {String}
151
$.secureEvalJSON = typeof JSON === 'object' && JSON.parse
157
.replace( /\\["\\\/bfnrtu]/g, '@' )
158
.replace( /"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, ']')
159
.replace( /(?:^|:|,)(?:\s*\[)+/g, '');
161
if ( /^[\],:{}\s]*$/.test( filtered ) ) {
162
return eval( '(' + src + ')' );
164
throw new SyntaxError( 'Error parsing JSON, source is not valid.' );
170
* Returns a string-repr of a string, escaping quotes intelligently.
171
* Mostly a support function for toJSON.
173
* >>> jQuery.quoteString('apple')
176
* >>> jQuery.quoteString('"Where are we going?", she asked.')
177
* "\"Where are we going?\", she asked."
179
$.quoteString = function( string ) {
180
if ( string.match( escapeable ) ) {
181
return '"' + string.replace( escapeable, function( a ) {
183
if ( typeof c === 'string' ) {
187
return '\\u00' + Math.floor(c / 16).toString(16) + (c % 16).toString(16);
190
return '"' + string + '"';