>> "Again, though, you should probably be modifying your busted server-side code to stop sending malformed JSON!"
I still think it was a silly mistake to impose a 'must be enclosed in quotes' rule for JSON parsing in js.
Those quotes are just wasted extra bytes. Needless.
Yeah sure, you can argue that someone silly will use a reserved word, like {new:"hello"}.
But I don't think that's a good enough reason to waste more bandwidth+time for those that know what they're doing.
either way I still think its great that libraries are taking the risk to not support malformed dataformats, if browser developers had of made the same decision I think the web would have been far ahead of where it is now
In some way the browsers already have made the decision. The new JSON.parse method available in Firefox, Safari, and IE 8 is capable of parsing a valid JSON string and turning it into a JavaScript object. The exception is the one provided by Chrome, as it accepts malformed JSON strings (such as {foo:1} and {'foo':1}).
In jQuery we wanted to take advantage of this new JSON.parse method for speed and security - but we couldn't have it throwing malformed JSON exceptions in some browsers but not others, so we simply equalized the field (throwing an exception in all browsers).
For some reason, the performance doesn't seem that clear cut.
For instance, I get the following on Chrome, running it a few times:
(Doing 100,000 parses of a small JSON string)
JSON: (1653ms) vs eval: (206ms)
Firefox the two are about even (650ms). Safari is also pretty much identical (250ms).
Surprising that the Chrome JSON parse is so much slower than eval.
Do you have any performance figures for JSON parsing?
So you have JSON.parse which is the same, if not slower (Chrome) than using eval. Having to include extra unnecessary characters costs you bandwidth, but you do get the slightly better security from JSON, although that can be done with a quick regexp beforehand.
{foo:1} should be valid dammit. It tells us exactly all we need to know, with 0 ambiguity.
So yeah, a bit faster in Firefox and Safari, much much faster in IE 8 (the one that matters), and oddly slower in Chrome. I'll go out on a limb and blame their lax parsing (they support malformed strings).
In the end though the parsing is a distant second to the improved security: Guaranteeing that eval will never get touched in modern browsers is a huge win from a framework perspective.
I completely disagree with this. JSON is a spec. Server-side code needs to support that spec. Adding extra eval() to support bad data formats hurts client performance and adds needless complexity. And extra quotes does not add a lot of data overhead. Especially compared to transmitting XML over the wire
he was mostly saying the specs (crockfords) decision was wrong, not jquerys to support it.
I dont really agree, naunces like reserved words causing bugs are major irritations and ill happily put up with a few extra bytes to never deal with them
I don't like it. I should have a choice whether to use quotes or not, and let me suffer the consequences. I don't like API's forcing "best practices" on me. The quotes add crappy visual noise and extra bytes.
But it's not an API, it's a data format, very different things! Supporting both just means there's two ways to say the same thing and every single parsing library has to have that extra case and the spec is just that little bit longer. I'll take the extra couple of bytes thanks :)
I had a problem with this today when upgrading from jQuery 1.3.2 to 1.4. The AJAX functions worked fine in Firefox, were returning "parseerror" in Safari because there was a non-UTF-8 character in the JSON response.
which is missing the quotes around foo so it should be:
{"foo": "bar"}
Since both of those would have had the same meaning the JSON spec sensibly restricts things so that only one is valid. See http://json.org/ for the (very short and readable) spec.
The reason for outlawing the first syntax is that it isn't a legal javascript literal in the case where the key is a javascript reserved word (if we change 'foo' to 'for' in this example).
I still think it was a silly mistake to impose a 'must be enclosed in quotes' rule for JSON parsing in js.
Those quotes are just wasted extra bytes. Needless.
Yeah sure, you can argue that someone silly will use a reserved word, like {new:"hello"}. But I don't think that's a good enough reason to waste more bandwidth+time for those that know what they're doing.