天天看點

JSON.parse()和jQuery.parseJSON()的差別

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()和jQuery.parseJSON()的差別

 差別:

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 &amp;&amp; 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>

繼續閱讀