转:关于JSON.parse(),JSON.stringify(),jQuery.parseJSON()的用法

本文详细介绍了JSON.parse()和jQuery.parseJSON()两种JSON解析方法,包括它们如何将JSON字符串转换为JavaScript对象,以及两者的区别。针对不同浏览器的支持情况进行了讨论,并提供了具体的代码示例。

1. JSON.parse(jsonString): 在一个字符串中解析出JSON对象

?
1
2
3
var str = '[{"href":"baidu.com","text":"test","orgId":123,"dataType":"curry","activeClass":"haha"}]' ;
  
JSON.parse(str);

结果:

2. JSON.stringify(obj) : 将一个JSON对象转换成字符串

?
1
2
3
var obj = [{ "href" : "baidu.com" , "text" : "test" , "orgId" :123, "dataType" : "curry" , "activeClass" : "haha" }];
  
JSON.stringify(obj);

结果:

?
1
"[{" href ":" baidu.com "," text ":" test "," orgId ":123," dataType ":" curry "," activeClass ":" haha "}]"

3. jQuery.parseJSON(jsonString) : 将格式完好的JSON字符串转为与之对应的JavaScript对象

?
1
2
3
var str = '[{"href":"baidu.com","text":"test","orgId":123,"dataType":"curry","activeClass":"haha"}]' ;
  
jQuery.parseJSON(str);

结果:

4.JSON.parse()和jQuery.parseJSON()的区别:

有的浏览器不支持JSON.parse()方法,使用jQuery.parseJSON()方法时,在浏览器支持时会返回执行JSON.parse()方法的结果,否则会返回类似执行eval()方法的结果,以上结论参考jquery 1.9.1 得出:

?
1
2
3
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
parseJSON: function ( data ) {
   // Attempt to parse using the native JSON parser first
   if ( window.JSON && window.JSON.parse ) {
     return window.JSON.parse( data );
   }
  
  
   if ( data === null ) {
     return data;
   }
  
  
   if ( typeof data === "string" ) {
  
  
     // Make sure leading/trailing whitespace is removed (IE can't handle it)
     data = jQuery.trim( data );
  
  
     if ( data ) {
       // Make sure the incoming data is actual JSON
       // Logic borrowed from http://json.org/json2.js
       if ( rvalidchars.test( data.replace( rvalidescape, "@" )
         .replace( rvalidtokens, "]" )
         .replace( rvalidbraces, "" )) ) {
  
  
         return ( new Function( "return " + data ) )();
       }
     }
   }
  
  
   jQuery.error( "Invalid JSON: " + data );
},

   我当时搜这篇文章是搜的问题是‘JSON.parse()和jQuery.parseJSON()的区别’,刚接触json的也注意一下这个问题~觉得好的花Ctrl+D或关注我一下,谢谢!

转载于:https://www.cnblogs.com/yzb23/p/6524586.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值