RELATEED CONSULTING
相关咨询
选择下列产品马上在线沟通
服务时间:8:30-17:00
你可能遇到了下面的问题
关闭右侧工具栏

新闻中心

这里有您想知道的互联网营销解决方案
javascript解析json,javascript解析字符串

js怎么解析json格式字符串

html

在汝阳等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供成都网站制作、网站建设 网站设计制作按需策划设计,公司网站建设,企业网站建设,成都品牌网站建设,营销型网站,外贸网站建设,汝阳网站建设费用合理。

head

script type="text/javascript"

var data = '{"return_code":0,"return_message":"success","data":{"data":[{"id":"1","question":"公主令牌在哪交?"},{"id":"2","question":"公主护使有什么用?"},{"id":"3","question":"角斗场在哪?"},{"id":"4","question":"北部断层在哪?"},{"id":"5","question":"欢乐令有什么用?"},{"id":"6","question":"令牌积分有什么用?"},{"id":"7","question":"南部断层在哪?"},{"id":"8","question":"大妖魔令牌交给谁?"},{"id":"9","question":"神工坊在哪?"},{"id":"10","question":"警戒妖珠有什么用?"}]}}';

function ShowData(){

var obj = eval("("+data+")");

alert("return_code:"+obj["return_code"]);

alert("return_message:"+obj["return_message"]);

alert("第一个问题id:" + obj["data"]["data"][0]["id"]);

alert("第一个内容id:" + obj["data"]["data"][0]["question"]);

}

/script

/head

body onload="ShowData();"

{"return_code":0,"return_message":"success","data":{"data":[{"id":"1","question":"公主令牌在哪交?"},{"id":"2","question":"公主护使有什么用?"},{"id":"3","question":"角斗场在哪?"},{"id":"4","question":"北部断层在哪?"},{"id":"5","question":"欢乐令有什么用?"},{"id":"6","question":"令牌积分有什么用?"},{"id":"7","question":"南部断层在哪?"},{"id":"8","question":"大妖魔令牌交给谁?"},{"id":"9","question":"神工坊在哪?"},{"id":"10","question":"警戒妖珠有什么用?"}]}}

/body

/html

js解析json字符串报错解决方案(带有转义字符的json字符串)

场景:从后台请求回来的数据中带有json格式的字符串,需要处理成json对象才能进行操作。

JSON.parse():

    使用JSON.parse方法来解析json字符串。

报错:      Uncaught SyntaxError: Unexpected token } in JSON at position 30

            Uncaught SyntaxError: Unexpected token ' in JSON at position 1

     这种报错是由于,json字符串的格式有问题,json字符串中对象的最后一个元素后面不可以再加','逗号了。比如'{ "name": "cxh", "sex": "man",}'使用JSON.parse()就会报错,而且 在json字符串中键值对需要用双引号引起来。

解决方案:使用eval()

报错:SyntaxError: Unexpected token e in JSON at position 1

由于请求回来的json中带有转义字符,所以才会报这个错误。

解决方案:带有转义字符的json字符串使用json

json数据使用JSON.parse()有浏览器是不兼容JSON这个对象的,或者有的里面有JSON.parse解析不了的东西,所以暂时还是使用: eval("("+data+")");

json源数据字符有转义符应该是必须的,你要看解析出来后是否有多余的转义符

json转字符串JSON.stringify总体效果还可以:

前导 0 和小数点报错:SyntaxError: JSON.parse: expected ',' or '}' after property value

                                  SyntaxError: JSON.parse: unterminated fractional number

                               Uncaught SyntaxError: Unexpected number in JSON at position 25

                               Uncaught SyntaxError: Unexpected token } in JSON at position 26

                                 

数字不能用 0 开头,比如01,并且你的小数点后面必须跟着至少一个数字。

js解析json文件,获取数据

根据返回的字符串可以看出是多个json拼接成的js数组的形式。

如果返回的只是字符串须现将字符串转成js对象。

使用Jquery的$.each()方法循环js数组取出每一个json对象的数据。

str = '[{"key":"value","keys":[{"key1":"value1","key2":"value2"},{"key1":"value3","key2":"value4"}],"obj":{"id":1,"msg":"success"}}]';

str_json = eval("(" + str + ")");//将字符串转换成js对象

$.each(str_json,fucntion(a,b){

alert(a);//弹出数组的key

alert(b.id);//弹出要取出的数据

});

javascript如何处理json数据

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。它基于ECMAScript的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C、C++、C#、Java、JavaScript、Perl、Python等)。这些特性使JSON成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成(一般用于提升网络传输速率)。

JSON的规则很简单: 对象是一个无序的“‘名称/值'对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值' 对”之间使用“,”(逗号)分隔。具体细节参考

举个简答的例子如图:

这表示一个user对象,拥有username, age, info, address 等属性。

同样也可以用JSON来简单的修改数据,修改上面的例子

这样就可以处理啦。

如何用nodejs来解析json数据

第一,我们需要在ubuntu14.04上安装nodejs,我们可以使用如下命令:

$ sudo apt-get install nodejs

安装完毕, 我们可以使用如下命令进行测试:

$ nodejs -v

v0.10.25

第二,准备一个测试json文件, test.json,内容如下:

[javascript] view plain copy

{

"person": {

"name": "wanger",

"birth": "1999"

}

}

第三,创建js脚本来解析json文件,main.js

[javascript] view plain copy

#!/usr/bin/nodejs

var cwd = process.argv[1].substring(0, process.argv[1].lastIndexOf("/"));

var fs = require('fs');

function load(file, cb) {

fs.readFile(file, function(err, data) {

if (err)

throw err;

cb(JSON.parse(data.toString()));

});

}

(function() {

if (process.argv.length 2) {

console.log("usage\n\t" + process.argv[1] + " loadfile");

return;

}

load(process.argv[2], function(obj) {

console.log("%s\n", obj.person.name);

console.log("%s\n", obj.person.birth);

});

})();

第四,测试和运行

$ ./main.js test.json

wanger

1999


当前文章:javascript解析json,javascript解析字符串
文章分享:http://scpingwu.com/article/dsddpoi.html