Make sure leading whitespace is trimmed for parseJSON. Fixes #6031.

This commit is contained in:
jeresig 2010-02-13 02:14:23 -05:00
parent 8b86004f9c
commit 94d925cd46
2 changed files with 7 additions and 2 deletions

View file

@ -480,6 +480,9 @@ jQuery.extend({
if ( typeof data !== "string" || !data ) {
return null;
}
// Make sure leading/trailing whitespace is removed (IE can't handle it)
data = jQuery.trim( data );
// Make sure the incoming data is actual JSON
// Logic borrowed from http://json.org/json2.js

View file

@ -807,7 +807,7 @@ test("jQuery.proxy", function(){
});
test("jQuery.parseJSON", function(){
expect(7);
expect(8);
equals( jQuery.parseJSON(), null, "Nothing in, null out." );
equals( jQuery.parseJSON( null ), null, "Nothing in, null out." );
@ -815,6 +815,8 @@ test("jQuery.parseJSON", function(){
same( jQuery.parseJSON("{}"), {}, "Plain object parsing." );
same( jQuery.parseJSON('{"test":1}'), {"test":1}, "Plain object parsing." );
same( jQuery.parseJSON('\n{"test":1}'), {"test":1}, "Make sure leading whitespaces are handled." );
try {
jQuery.parseJSON("{a:1}");
@ -829,4 +831,4 @@ test("jQuery.parseJSON", function(){
} catch( e ) {
ok( true, "Test malformed JSON string." );
}
});
});