JS操作JSON总结

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,是理想的数据交换格式。同时,JSON是 JavaScript 原生格式,这意味着在 JavaScript 中处理 JSON数据不须要任何特殊的 API 或工具包。

    本文主要是对JS操作JSON的要领做下总结。

    在JSON中,有两种结构:对象和数组。

    1. 一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值’ 对”之间运用 “,”(逗号)分隔。 名称用引号括起来;值如果是字符串则必须用括号,数值型则不须要。例如:

    var o={"xlid":"cxh","xldigitid":123456,"topscore":2000,"topplaytime":"2009-08-20"};

    2. 数组是值(value)的有序集合。一个数组以“[”(左中括号)开始,“]”(右中括号)结束。值之间运用 “,”(逗号)分隔。

    例如:

    var jsonranklist=[{"xlid":"cxh","xldigitid":123456,"topscore":2000,"topplaytime":"2009-08-20"},{"xlid":"zd","xldigitid":123456,"topscore":1500,"topplaytime":"2009-11-20"}];

    为了方便地处理JSON数据,JSON提供了json.js包,下载地址:http://www.json.org/json.js

    在数据传输流程中,json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键。例如:

    JSON字符串:

    var str1 = '{ "name": "cxh", "sex": "man" }';

    JSON对象:

    var str2 = { "name": "cxh", "sex": "man" };

    一、JSON字符串转换为JSON对象

    要运用上面的str1,必须运用下面的要领先转化为JSON对象:

    //由JSON字符串转换为JSON对象

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

或者

    var obj = str.parseJSON(); //由JSON字符串转换为JSON对象

    或者

    var obj = JSON.parse(str); //由JSON字符串转换为JSON对象

    然后,就可以这样读取:

    Alert(obj.name);

    Alert(obj.sex);

    特别留心:如果obj本来就是一个JSON对象,那么运用 eval()函数转换后(哪怕是多次转换)还是JSON对象,但是运用 parseJSON()函数处理后会有疑问(抛出语法异常)。

    二、可以运用 toJSONString()或者全局要领 JSON.stringify()将JSON对象转化为JSON字符串。

    例如:

    var last=obj.toJSONString(); //将JSON对象转化为JSON字符

    或者

    var last=JSON.stringify(obj); //将JSON对象转化为JSON字符

    alert(last);

    留心:

    上面的多个要领中,除了eval()函数是js自带的之外,其他的多个要领都来自json.js包。新版本的 JSON 修改了 API,将 JSON.stringify() 和 JSON.parse() 两个要领都注入到了 Javascript 的内建对象里面,前者变成了 Object.toJSONString(),而后者变成了 String.parseJSON()。如果提示找不到toJSONString()和parseJSON()要领,则说明您的json包版本太低。

更多相关文章
  • function addServerUrlToJson() { var json_tem = [{"name":"a","value":1}]; var arr = { "name" : "aaa", ...
  • 在数据传输过程中,json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键.例如: JSON字符串: var str1 = '{ "name": "cxh", "sex": ...
  • 要引入:jquery-json-2.4.js 在数据传输过程中,json是以文本,即字符串的形式传递的,而JS操作的是JSON对象,所以,JSON对象和JSON字符串之间的相互转换是关键.例如: JSON字符串: var str1 = '{ "name": "cxh&q ...
  • <?php $array =array('fds','fdsa','fdsafasd');  // json_encode($array);?> <html> <head> <script type="text/javascript"&g ...
  • ajax基础信息前面都已经介绍过了.这个就略过.使用原生js操作ajax的话还是比较容易的,跟前面的一篇内容基本差不多.使用步骤:一.创建对象 XMLHTTPRequest/ActiveOBject二.发送请求 open().send()三.服务器响应 responseText(onreadysta ...
  • 最近要使用java来操作Json数据,虽然Json用过几次,但一直没有好好总结,趁这次来总结一下java操作Json数据.Java操作Json有很多工具包,地址为http://www.json.org/,可以自己上去挑选.     这里我使用第一个org.json,最新源码地址为:https://g ...
  • ThinkPHP表单提交操作成功后执行JS操作如何刷新父页面或关闭当前页等操作
    ThinkPHP 表单提交操作成功后执行JS操作如何刷新父页面或关闭当前页等操作 1.操作成功后刷新父页面 $this->assign('jumpUrl', "javascript:window.parent.location.reload();"); $this-> ...
  • 原文地址:http://www.uncletoo.com/html/base/673.htmlJSON 是一个轻量级的文本数据交换格式,他比 XML 更小.更快,更易解析,所以在PHP开发过程中,我们经常会用它来传递数据,本文UncleToo将个大家介绍一下PHP如何操作JSON数据PHP操作JSO ...
一周排行
  • 先去https://mp.weixin.qq.com 申请了一个帐号(这个要是有问题,自己撞墙去吧!)个人现在只能申请到订阅号.粗鲁的看来小半天,看来还得自己coding. 可是咱没服务器资源啊.找了半天,把百度找到 ...
  • 使用python可以很方便的操作数据库,刚刚开始学python,第一个脚本是导出数据库到指定位置,下面简明总结下python的数据库操作下载安装python环境,下载MySQLdb,MySQLdb是python的数据 ...
  • lamp架构部署
    最近在自己弄lamp的架构网站平台,而且兴致勃勃的为云服务器申请了网站备案,此贴记录我的l ...
  • 转自:http://www.linuxso.com/command/kill.html 有一次面试被问到kill -3的意思,回答的不是很好,于是找到一篇文件来学习一下.Linux kill 命令使用详解功能说明:删 ...
  • 用户.组.权限安全上下文(secure context)权限:r,w,x文件:r:可读,可以使用类似cat等命令查看文件内容w:可写,可以 编辑或删除此文件x:可执行,可以在命令提示符下当作命令提交给内核运行目录:r ...
  • 在proxy上设置:(安装时需要添加--with-http_realip_module)proxy_set_header Host $host;proxy_set_header X-Forwarded-For $re ...
  • 截断事务日志 如果从来没有从事务日志中删除日志记录,逻辑日志就会一直增长,直到填满容纳物理日志文件的磁盘上的所有可用空间.在某个即时点,必须删除恢复或还原数据库时不再需要的旧日志记录,以便为新日志记录腾出空间.删除这 ...
  • 今天收到了第一卷.主要是之前看了第二卷的大纲,给写了一个"美言几句"的介绍,写完其实有点担心,虽然知道作者的技术底子足够厚,也知道作者的态度足够端正,但是还是担心写书毕竟是新鲜事,万一作者把握不好 ...
  • JVM调优总结-序    几年前写过一篇关于JVM调优的文章,前段时间拿出来看了看,又添加了一些东西.突然发现,基础真的很重要.学习的过程是一个由表及里,再由里及表的过程.呵呵,所谓的"温故而知新" ...
  •    今天想起来很惆怅.做程序员已经五六年的时间了.因为大学学的是计算机应用专业,所以,理所当然的做起程序员的行当.我为什么用行当一词来形容.说实话,我并不喜欢这个行业.我觉得这只是我一个吃饭的饭碗.在这里我看不到未 ...