jQuery.parseJSON(jsonString) : 将格式完好的JSON字元串轉為與之對應的JavaScript對象 (jquery 方法)
1
2
3
<code>var</code> <code>str = </code><code>'[{"href":"baidu.com","text":"test","orgId":123,"dataType":"curry","activeClass":"haha"}]'</code><code>;</code>
<code>jQuery.parseJSON(str);</code>
結果:

差別:
JSON.parse()是js方法,jQuery.parseJSON()是jquery方法有的浏覽器不支援JSON.parse()方法,使用jQuery.parseJSON()方法時,在浏覽器支援時會傳回執行JSON.parse()方法的結果,否則會傳回類似執行eval()方法的結果,以上結論參考jquery 1.9.1 得出:
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<code>parseJSON: </code><code>function</code><code>( data ) {</code>
<code> </code><code>// Attempt to parse using the native JSON parser first</code>
<code> </code><code>if</code> <code>( window.JSON && window.JSON.parse ) {</code>
<code> </code><code>return</code> <code>window.JSON.parse( data );</code>
<code> </code><code>}</code>
<code> </code><code>if</code> <code>( data === </code><code>null</code> <code>) {</code>
<code> </code><code>return</code> <code>data;</code>
<code> </code><code>if</code> <code>( </code><code>typeof</code> <code>data === </code><code>"string"</code> <code>) {</code>
<code> </code><code>// Make sure leading/trailing whitespace is removed (IE can't handle it)</code>
<code> </code><code>data = jQuery.trim( data );</code>
<code> </code><code>if</code> <code>( data ) {</code>
<code> </code><code>// Make sure the incoming data is actual JSON</code>
<code> </code><code>// Logic borrowed from http://json.org/json2.js</code>
<code> </code><code>if</code> <code>( rvalidchars.test( data.replace( rvalidescape, </code><code>"@"</code> <code>)</code>
<code> </code><code>.replace( rvalidtokens, </code><code>"]"</code> <code>)</code>
<code> </code><code>.replace( rvalidbraces, </code><code>""</code><code>)) ) {</code>
<code> </code><code>return</code> <code>( </code><code>new</code> <code>Function( </code><code>"return "</code> <code>+ data ) )();</code>
<code> </code><code>}</code>
<code> </code><code>}</code>
<code> </code><code>jQuery.error( </code><code>"Invalid JSON: "</code> <code>+ data );</code>
<code>},</code>