使用js把json字符串转为js对象的方法

ECMA-262(E3) 中没有将JSON概念写到标准中,还好在 ECMA-262(E5)中JSON的概念被正式引入了,包括全局的JSON对象和Date的toJSON方法。

1,eval方式解析,恐怕这是最早的解析方式了。如下:

复制代码代码如下:

function strToJson(str){ 
var json = eval(‘(‘ + str + ‘)‘); 
return json; 
}

记得别忘了str两旁的小括号。

这里属性名可以使用数字,可以带引号也可以不带引号。如果属性名是纯数字,生成的对象属性可以用下表运算符[]来访问,不能用obj.123这样的方式访问。

 1         var str1 = "{\"fa\":123,fb:333,\"fc\":\"xxx\",123:‘xyz‘}";
 2         var obj1 = eval("(" + str1 + ")");
 3         document.writeln("obj1.fa=" + obj1.fa);
 4         document.writeln("obj1.fb=" + obj1.fb);
 5         document.writeln("obj1.fc=" + obj1.fc);
 6         //document.writeln("obj1.123=" + obj1.123);//语法错误
 7         document.writeln("obj1[fa]=" + obj1["fa"]);
 8         document.writeln("obj1[fb]=" + obj1["fb"]);
 9         document.writeln("obj1[fc]=" + obj1["fc"]);
10         document.writeln("obj1[123]=" + obj1[123]);
11         document.write("<br/>");

2,new Function形式,比较怪异哦。如下

复制代码代码如下:

function strToJson(str){ 
var json = (new Function("return " + str))(); 
return json; 
}

 1         var str2 = "{\"fa\":123,fb:333,\"fc\":\"xxx\",123:‘xyz‘}";
 2         var obj2 = (new Function("return" + str2))();
 3         document.writeln("obj2.fa=" + obj2.fa);
 4         document.writeln("obj2.fb=" + obj2.fb);
 5         document.writeln("obj2.fc=" + obj2.fc);
 6         //document.writeln("obj1.123=" + obj1.123);
 7         document.writeln("obj2[fa]=" + obj2["fa"]);
 8         document.writeln("obj2[fb]=" + obj2["fb"]);
 9         document.writeln("obj2[fc]=" + obj2["fc"]);
10         document.writeln("obj2[123]=" + obj2[123]);
11         document.write("<br/>");

3,使用全局的JSON对象,如下:

复制代码代码如下:

function strToJson(str){ 
return JSON.parse(str); 
}

目前 IE8(S)/Firefox3.5+/Chrome4/Safari4/Opera10 已实现了该方法,以下是部分资料:http://blogs.msdn.com/ie/archive/2008/09/10/native-json-in-ie8.aspx https://developer.mozilla.org/en/Using_JSON_in_Firefox 
使用JSON.parse需严格遵守JSON规范,如属性都需用引号引起来,如下

复制代码代码如下:

var str = ‘{name:"jack"}‘; 
var obj = JSON.parse(str); // --> parse error

name没有用引号引起来,使用JSON.parse所有浏览器中均抛异常,解析失败。而前两种方式则没问题。 另外必须用双引号包围属性名,单引号会有解析错误,范例:

 1         var str3 = "{\"fa\":123,\"fb\":333,\"fc\":\"xxx\",\"123\":321}";
 2         var obj3 = JSON.parse(str3);
 3         document.writeln("obj3.fa=" + obj3.fa);
 4         document.writeln("obj3.fb=" + obj3.fb);
 5         document.writeln("obj3.fc=" + obj3.fc);
 6         //document.writeln("obj1.123=" + obj1.123);
 7         document.writeln("obj3[fa]=" + obj3["fa"]);
 8         document.writeln("obj3[fb]=" + obj3["fb"]);
 9         document.writeln("obj3[fc]=" + obj3["fc"]);
10         document.writeln("obj3[123]=" + obj3[123]);
11         document.write("<br/>");
12
13         try{
14             var str4 = "{fa:123,\"fb\":333,\"fc\":\"xxx\",\"123\":321}";
15             var obj4 = JSON.parse(str4);
16         } catch (err) {
17             document.write(err.name+":"+err.message);
18         }
19         document.write("<br/>");
20         try{
21             var str5 = "{‘fa‘:123,\"fb\":333,\"fc\":\"xxx\",\"123\":321}";
22             var obj5 = JSON.parse(str4);
23         } catch (err) {
24             document.write(err.name + ":" + err.message);
25         }

另见:Chrome中JSON.parse的特殊实现

使用js把json字符串转为js对象的方法

时间: 2024-10-16 05:32:17

使用js把json字符串转为js对象的方法的相关文章

js 把json字符串转为json对象

   <input type="hidden" name="data" id="data" value='[{"name":"北京","value":1,"children":[{"name":"北京市1","value":12,"children":[{"name&quo

js 将json字符串转换为json对象的方法解析(转)

js 将json字符串转换为json对象的方法解析 将json字符串转换为json对象的方法.在数据传输过程中,json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键 例如: JSON字符串:var str1 = '{ "name": "cxh", "sex": "man" }'; JSON对象:var str2 = { "name": &

js中json字符串转成js对象

json字符串转成js对象我所知的方法有2种: //json字符串转换成json对象 var str_json = "{name:'liuchuan'}"; //json字符串 //1. 函数对象构造定义 var obj1 = new Function("return " + str_json)(); console.log(obj1.name); //2. eval函数 var obj2 = eval("(" + str_json + &quo

js 将json字符串转换为json对象

要引入:jquery-json-2.4.js 在数据传输过程中,json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键.例如: JSON字符串: var str1 = '{ "name": "cxh", "sex": "man" }'; JSON对象: var str2 = { "name": "cxh", "

JSON字符串和JS对象之间的转换

1 json字符串转换为js对象 1.1 标准json格式字符串转换为Js对象 JSON字符串 str JSON.parse(str) eval(str) eval('('+str+')') eval('['+str+']') 对象字符串 "{\"id\":\"001\",\"name\":\"sanzhang\"}" 对应的json格式 {"id":"001",&q

php json字符串转为数组或对象

从网上查到的方法是 用get_object_vars 把类类型转换成数组 然后在用foreach  遍历即可 $array = get_object_vars($test); $json= '[{"id":"1","name":"\u5f20\u96ea\u6885","age":"27","subject":"\u8ba1\u7b97\u673a\u79d

DataTable转json字符串,jQuery.parseJSON()把json字符串转为标准的json对象格式

1.string res = DataTableToJson.DataTable2Json(dt);讲DataTable转换为json字符串 http://www.365mini.com/page/jquery_parsejson.htm 2.jQuery.parseJSON()函数用于将格式完好的JSON字符串转为与之对应的JavaScript对象  var res = $.parseJSON(data).ds

Json对象与Json字符串的转化、JSON字符串与Java对象的转换

Json对象与Json字符串的转化.JSON字符串与Java对象的转换 一.Json对象与Json字符串的转化 1.jQuery插件支持的转换方式: $.parseJSON( jsonstr ); //jQuery.parseJSON(jsonstr),可以将json字符串转换成json对象 2.浏览器支持的转换方式(Firefox,chrome,opera,safari,ie9,ie8)等浏览器: JSON.stringify(obj)将JSON转为字符串.JSON.parse(string)

json字符串转换成对象,对象转换成json字符串

方法一: 程序集:  System.Web.Extensions; 命名空间:System.Web.Script.Serialization; 最重要的类:JavaScriptSerializer //实例化 JavaScriptSerializer js = new JavaScriptSerializer(); js.Serialize();//将对象转换成json字符串:    序列号 js.Deserialize();//将json字符串转换成对象:  反序列化 方法二: 程序集:New