码迷,mamicode.com
首页 > Web开发 > 详细

Json基础

时间:2014-11-27 20:33:42      阅读:227      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   io   ar   使用   sp   java   文件   

一、是什么?

         JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。易于人阅读和编写同时也易于机器解析和生成。它基于JavaScript的一个子集,是JavaScript对象表示法,是存储和交换文本信息的语法。类似XMLJSONXML更小,更快,更易解析。

二、语法

         Json 语法是JavaScript对象表示法的子集:

         1. 数据在名称/值对中

         2.数据由逗号分隔

         3.花括号保存对象

         4.方括号保存数组

         如果明白了这些规则,那么问题又来了?Json值的类型又有什么呢?接下来就分享一下:

          Json值类型可以为数字(整数或浮点数)、字符串(在双引号中)、逻辑值(truefalse)、数组(在方括号中)、对象(在花括号中)、null     

三、转换为Javascript对象

        Json 最常见的用法之一,是从web 服务器上读取Json 数据(作为文件或作为 HttpRequest),将Json 数据转换为 JavaScript 对象,然后在网页中使用该数据。那么怎么将Json语法转化目标对象呢?接下来介绍两种方式:

          1.eval()函数

           eval()Javascript的一个函数,它可以将Json文本转化为Javascript对象。

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

<span style="font-size:24px;"> var txt = '{"employees" : [' +
'{"firstName":"Bill" , "lastName":"Gates"},' +
'{"firstName":"George" ,"lastName":"Bush" },' +
'{"firstName":"Thomas" ,"lastName":"Carter" } ]}';</span>

          转化:        

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

         2.Json解析器

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

         使用 Json解析器将Json转换为JavaScript对象是更安全的做法。Json解析器只能识别 Json文本,而不会编译脚本。在浏览器中,这提供了原生的 Json支持,而且Json解析器的速度更快。由于没有用过,这里就不详细介绍啦!

四、与XML的比较

           1.可读性方面。

           Json和XML的数据可读性基本相同,Json和XML的可读性可谓不相上下,一边是建议的语法,一边是规范的标签形式,XML可读性较好些。

        2.可扩展性方面。

           XML天生有很好的扩展性,Json当然也有,没有什么是XML能扩展,Json不能的。

           3.编码难度方面。

            XML有丰富的编码工具,比如Dom4j、JDom等,Json也有json.org提供的工具,但是Json的编码明显比XML容易许多,即使不借助工具也能写出Json的代码,可是要写好XML就不太容易了。

           4.解码难度方面。

            XML的解析得考虑子节点父节点,让人头昏眼花,而Json的解析难度几乎为0。这一点XML输的真是没话说。

五、总结

         这些东西本来早就该详细的了解下,但就是由于自己犯懒,知道有这么回事,知道几个用法就以为全回了,直到现在工作用到了才感觉到后悔。所以在今后的学习中如果遇到新的知识点一定要把它弄明白了,这样用的时候才会得心应手。

Json基础

标签:style   blog   http   io   ar   使用   sp   java   文件   

原文地址:http://blog.csdn.net/liu_yujie2011com/article/details/41551561

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!