把 JSON 文本转换为 JavaScript 对象

JSON 最常见的用法之一,是从 web 服务器上读取 JSON 数据(作为文件或作为 HttpRequest),将 JSON 数据转换为 JavaScript 对象,然后在网页中使用该数据。

为了更简单地为您讲解,我们使用字符串作为输入进行演示(而不是文件)。


JSON 实例 - 来自字符串的对象

创建包含 JSON 语法的 JavaScript 字符串:

var txt = '{ "sites" : [' + '{ "name":"菜鸟教程" , "url":"www.runoob.com" },' + '{ "name":"google" , "url":"www.google.com" },' + '{ "name":"微博" , "url":"www.weibo.com" } ]}';

由于 JSON 语法是 JavaScript 语法的子集,JavaScript 函数 eval() 可用于将 JSON 文本转换为 JavaScript 对象。

eval() 函数使用的是 JavaScript 编译器,可解析 JSON 文本,然后生成 JavaScript 对象。必须把文本包围在括号中,这样才能避免语法错误:

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

在网页中使用 JavaScript 对象:

实例

var txt = '{ "sites" : [' + '{ "name":"菜鸟教程" , "url":"www.runoob.com" },' + '{ "name":"google" , "url":"www.google.com" },' + '{ "name":"微博" , "url":"www.weibo.com" } ]}'; var obj = eval ("(" + txt + ")"); document.getElementById("name").innerHTML=obj.sites[0].name document.getElementById("url").innerHTML=obj.sites[0].url

JSON 解析器

  eval() 函数可编译并执行任何 JavaScript 代码。这隐藏了一个潜在的安全问题。

使用 JSON 解析器将 JSON 转换为 JavaScript 对象是更安全的做法。JSON 解析器只能识别 JSON 文本,而不会编译脚本。

在浏览器中,这提供了原生的 JSON 支持,而且 JSON 解析器的速度更快。

较新的浏览器和最新的 ECMAScript (JavaScript) 标准中均包含了原生的对 JSON 的支持。

Web 浏览器支持 Web 软件支持
  • Firefox (Mozilla) 3.5
  • Internet Explorer 8
  • Chrome
  • Opera 10
  • Safari 4
  • jQuery
  • Yahoo UI
  • Prototype
  • Dojo
  • ECMAScript 1.5

对于较老的浏览器,可使用 JavaScript 库: https://github.com/douglascrockford/JSON-js

JSON 格式最初是 originally specified by Douglas Crockford

最新文章

  1. ccpc_南阳 C The Battle of chibi dp + 树状数组
  2. codeforce No to Palindromes!(枚举)
  3. MVC模式介绍
  4. 转:一个Sqrt函数引发的血案
  5. 理解squid的正向和反向代理
  6. Request Session生命周期及struts1 中service的编写
  7. C puzzles详解【1-5题】
  8. 结队开发项目—NABC模型
  9. form 转json最佳示例
  10. Candy 解答
  11. jQuery 源码分析和使用心得 - 关于源码
  12. javascript(3)
  13. Spring4-@Enable** 注解的实现原理
  14. Java开发工程师面试题1
  15. [Python_7] Python Socket 编程
  16. 点击除元素以外的任意地方隐藏元素js
  17. WorkSpace
  18. Myeclipse文件没出错,但是项目上显示有错的解决办法
  19. Client/Server 模型 与socket
  20. HDU 1059 Dividing (dp)

热门文章

  1. MySQL cmd操作
  2. XXX_initcall()函数分析
  3. HTML5学习:表格
  4. (十四)Linux kernel mmc 框架说明,包括mmc_test使用方法
  5. Djang简介
  6. 用VNC远程无线站
  7. Keras---Virtualenv 下安装Keras (基于Tensorflow后端)
  8. Java 扫描微信公众号二维码,关注并自动登录网站
  9. Anaconda 下 Jupyter 更改默认启动路径和默认浏览器
  10. 使用Ajax中get请求发送Token时踩的那些坑