您的位置:首页 > Web前端 > JavaScript

js操作Json数据,JSON对象与字符串转化

2014-06-30 15:19 756 查看
一、JSON格式数据介绍

书写AJAX的时候,经常需要解析从服务器返回的一串字符串,这里简单介绍服务器返回字符的两种格式,及JS对它们的解析方法。

JSON即JS对象标记(JavaScript Object Notation),是一种以JS声明对象的方式组合的一串字符串。

JS可以按以下方式定义对象:

var obj =

{

     id: 2,

     name: 'n'

};

alert(obj.name);

这样就定义了对象 obj, 它有两个公共属性id和name,可以用 obj.id 的方式直接访问其属性值。

从服务器获取数据时往往不止一个对象,这就需要用到对象数组,JS中对象数组可以用 [] 来定义,如下:

var objs = [{ id: 1, name: 'n_1' }, { id: 2, name: 'n_2'}];

alert(objs[0].id);

这样就定义了对象数组 objs, 它包含两个对象,可以用索引来访问,如 objs[0] 将引用到第一个对象。到这里你或许已经想到服务器返回的字符串格式是怎样的,但字符串毕竟是字符串,我们需要将其转换为可以利用JS操作的变量。这就用到 eval 函数,请看下例:

var objs = eval("[{ id: 1, name: 'n_1' }, { id: 2, name: 'n_2'}]");

alert(objs[0].id); // return 1

二、构造Json对象

好了,根据上面的知识,在服务器端只要以格式:[{ id: 1, name: 'n_1' }, { id: 2, name: 'n_2'}] 返回字符串,在客户端就可以利用 eval() 执行返回的字符串,获得对象数组。以下用AJAX做一个简单的例子。用js取json的代码如下:

   var objs = eval(request.responseText);

       alert(objs.length); // 2

       alert(objs[0].id);  // 1

       alert(objs[1].name);// 'n_2'

再添加一个测试按钮即可以看到效果:

<input type="button" value="GetJson" onclick="getJson();" />

但有时,会遇到Json数据是自己拼接的情况,用js直接读,发现读出来的数据都是undefined...也就是说,像

var s = "{name1:'name1',name2:'name2'}";的情况,js是把它当作字符串,而不是JSON数据来处理的。所以,需要我们把它转化为JSON形数据。

注意,如果此时写:tmp = eval(tmp) 则会报"缺少;"的错误。应该是:tmp =eval("(" + tmp + ")");

然后再使用document.getElementById("txt1").value = tmp.name1;就可以了。

下面我列出来了常见的几种字符串转JSON的情况:

字符串转Json方法一

//字符串转Json方法1

function strToJson(str){

var json = eval('(' + str + ')');

return json;

}

======================【测试】===========================

var s = "{name1:'name1',name2:'name2'}";

alert(strToJson(s).name1);//此处可以正常使用

alert(strToJson("("+s+")").name2);//在外面多增加个括号也可以正常转换
因为通过以上可以看出,只有一个{}的情况,JS只把它做为一个对象进行操作.

var s2 = "[{name:'name1',age:'20'},{name:'name2',age:'20'}]";

var obj =strToJson(s2);

alert(obj.length);//显示长度为2

alert(obj[1].name);

var s3 = "[{name:'name1',age:'20'}]";

alert(strToJson(s3).length);//显示长度为1

alert(strToJson(s3)[0].name);
在最外层增加了中括号[]的情况下,里面有一对大括号{},还是多对个大括号,最后都产生一个数组对象

var s4 = "{name:'name1',age:'20'},{name:'name2',age:'22'},{name:'name3',age:'23'}";//此处做为逗号运算符

//alert(strToJson(s4).name);  //此处只显示最后的一个 name3
根据对s4的测试,如果有多个大括号,并且外层没有使用中括号[],则使用eval转换Json时候,先按逗号运算符,再把最后一个转换成Json对象,只会得到最后一个对象。

字符串转Json方法二

在使用了方法一的时候有人提出了安全问题,毕竟是一定是eval方法转换的嘛,可以执行任何的js代码。

下面给出第二种方法,以供你参考

//字符串转Json对象方法2

function parseJSON( strData ){

return (new Function( "return " + strData ))();

}

字符串转Json方法三

另有字符串转化为JSON的方法:   //需要json.js包

var obj = strJSON.parseJSON();

    var obj = JSON.parse(strJSON);

=================================================================================

下面说说如何把Json对象转换成字符串

Json对象转字符串方法一

//Json对象转字符串的方法

function json2str(obj)

{

  var S = [];

  for(var i in obj){

  obj[i] = typeof obj[i] == 'string'?'"'+obj[i]+'"':(typeof obj[i] == 'object'?json2str(obj[i]):obj[i]);

  S.push(i+':'+obj[i]);

  }

    return '{'+S.join(',')+'}';

}

Json对象转字符串方法二

将JSON转化为字符串,//需要json.js包

  var str = obj.toJSONString();

  var str = JSON.stringify(obj)

 

转载请注明出处:http://www.cnblogs.com/mq0036/archive/2013/09/05/3303018.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: