JavaScript解析json

后台数据经常以json数据格式传回前台,解析当然首选JSON对象。

JSON对象有两个方法,使用JSON.parse(str)可以将json字符串解析成js中的对象。

var o = JSON.parse(‘{"name":"zjz","age":"23"}‘);
console.log(o);
//Object {name: "zjz", age: "23"}

同时这个方法还可以接收第二个参数,这个参数是个函数,参数为转换后对象的键和对应的值。

JSON.parse(‘{"name":"zjz", "age":"23"}‘, function(key, value) {
    console.log(key + ‘:‘ + value)}
);
//name:zjz
//age:23 

与parse相对的是stringify函数,作用是将js对象序列化为一个json字符串。

var obj = {name: ‘zjz‘, age: ‘23‘};
var json = JSON.stringify(obj);
//"{"name":"zjz","age":"23"}"

但JSON对象IE8之前的浏览器不支持。

第二种方法,是通过eval。

eval(‘(‘ + ‘{"name":"zjz","age":"23"}‘ + ‘)‘);
//Object {name: "zjz", age: "23"}

需要注意的是在解析字符串的时候,需要在字符串之外加上括号,使其成为表达式,然后eval进行计算。

eval解析JSON中的注意点 这篇文章里讲的挺详细的。

大家都不建议用eval。

第三种方法,使用Function。

var o = new Function(‘return ‘ + ‘{"name":"zjz","age":"23"}‘)();
//Object {name: "zjz", age: "23"}

所以在解析JSON,可以先用parse,如果不支持再使用Function。

try {
      JSON.parse(str);
} catch(e) {
       try {
              return (new Function(‘return ‘ + str))();
       } catch(e) {
               alert(‘json error‘);
        }
}

文中的输出都是chrome浏览器下的开发者工具的输出结果。

时间: 2024-08-16 00:13:14

JavaScript解析json的相关文章

JavaScript -- 使用JavaScript解析JSON格式的字符串

JSON的规则很简单:对象是一个无序的"'名称/值'对"集合.一个对象以"{"(左括号)开始,"}"(右括号)结束.每个"名称"后跟一个":"(冒号):"'名称/值'对"之间使用","(逗号)分隔.具体细节参考http://www.json.org/json-zh.html 一直以来解析JSON都是使用的org.json包,进行的后台解析, http://blog.c

如何在QML应用中使用Javascript解析JSON

很多QML应需要访问web services.我们可以通过Javascript的方法来解析得到我们所需要的JSON数据,并把它们展示出来.在今天的例子中,我们将展示如何实现它? 我们可以创建一个最基本的"QML App with Simple UI (qmlproject)",并取名我们的应用为"baidutranslator".我们将使用的API为: http://openapi.baidu.com/public/2.0/bmt/translate?client_

VBA中使用JavaScript脚本语言解析JSON数据

JSON:JavaScript 对象表示法(JavaScript Object Notation) 和xml相似,都是文本形式(保存在文本文件中或字符串等形式),比如: jsstr = {"系别":"历史系","班级":"一班", "学员":[ {"姓名":"张三","年龄":25,"性别":"男"}, {&

在QML应用中使用JSONListModel来帮我们解析JSON数据

我们知道JSON数据在很多web service中被广泛使用.它在我以前的文章中都有被提到: - 如何读取一个本地Json文件并查询该文件展示其内容 - 如何在QML应用中使用Javascript解析JSON 在今天的这篇文章中,我来介绍一种类似像XmlListModel(解析XML)的方法来解析我们的JSON.这个方法更加简单直接.关于JSONListModel的介绍可以参照地址https://github.com/kromain/qml-utils. 我们今天就利用JSONListModel

JavaScript中解析JSON数据

1.eval()方法 解析JSON数据的最常用方法是使用javascript的eval()方法,代码如下: function toJson(str){ var json = eval('(' + str + ')'); return json;} 2.new Function方法 该方法存在性能和安全方面的问题,不建议使用. function toJson(str){ var json = (new Function("return " + str))(); return json;}

javascript如何解析json对javascript如何解析json对象并动态赋值到select列表象并动态赋值到select列表

原文 javascript如何解析json对象并动态赋值到select列表 JSON(JavaScriptObject Notation)一种简单的数据格式,比xml更轻巧.JSON是JavaScript原生格式,这意味着在JavaScript中处理JSON数据不需要任何特殊的API或工具包. JSON的规则很简单:对象是一个无序的“‘名称/值’对”集合.一个对象以“{”(左括号)开始,“}”(右括号)结束.每个“名称”后跟一个“:”(冒号):“‘名称/值’对”之间使用“,”(逗号)分隔. 在开

javascript 解析ajax返回的xml和json格式的数据

写个例子,以备后用 一.JavaScript 解析返回的xml格式的数据: 1.javascript版本的ajax发送请求 (1).创建XMLHttpRequest对象,这个对象就是ajax请求的核心,是ajax请求和响应的信息载体,单是不同浏览器创建方式不同 (2).请求路径 (3).使用open方法绑定发送请求 (4).使用send() 方法发送请求 (5).获取服务器返回的字符串   xmlhttpRequest.responseText; (6).获取服务端返回的值,以xml对象的形式存

JavaScript转换与解析JSON的方法

在JavaScript中将JSON的字符串解析成JSON数据格式,一般有两种方式: 一种为使用eval()函数. 使用Function对象来进行返回解析.缙云县外国专家局 使用eval函数来解析,jquery的each方法来遍历 用JQuery解析JSON数据的方法,作为JQuery异步请求的传输对象,JQuery请求后返回的结果是json对象,这里考虑的都是服务器返回JSON形式的字符串的形式,对于利用JSONObject等插件封装的JSON对象,与此亦是大同小异,这里不再做说明. 这里首先给

javascript 中解析json

首先温习一下JSON格式: (1) 单个对象{"变量名1":"变量值1","变量名2":"变量值2"} (2) 数组[{ "变量名11":"变量值1","变量名12":"变量值2" },{ "变量名21":"变量值1","变量名22":"变量值2" },{ "