博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【转】What is JSON:初识JSON
阅读量:5083 次
发布时间:2019-06-13

本文共 3353 字,大约阅读时间需要 11 分钟。

本篇介绍JSON的基础知识。在没有接触AJAX之前我还不知道什么是JSON,在读Jeffrey Zhao的《深入Atlas系列》时才看到这个词,所以有必要了解一下JSON。这里我结合今天初浅的认识及一个小练习记录我的学习。

JSON是什么?

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

JSON建构于两种结构:

  1. “名称/值”对的集合(A collection of name/value pairs)。不同的语言中,它被理解为对象(object)纪录(record)结构(struct)字典(dictionary)哈希表(hash table)有键列表(keyed list),或者关联数组 (associative array)
  2. 值的有序列表(An ordered list of values)。在大部分语言中,它被理解为数组(array)

这些都是常见的数据结构。事实上大部分现代计算机语言都以某种形式支持它们。这使得一种数据格式在同样基于这些结构的编程语言之间交换成为可能。

有关JSON的更多介绍,访问它的官方网站:

在JavaScript中使用JSON

JSON是JavaScript对象描述符号(object literal notation)的一个子集。正因为JSON是JavaScript的子集,所以在JavaScript中我们可以很容易的使用它。

var myJSONObject = {"bindings": [{"ircEvent": "PRIVMSG", "method": "newURI", "regex": "^http://.*"},{"ircEvent": "PRIVMSG", "method": "deleteURI", "regex": "^delete.*"},{"ircEvent": "PRIVMSG", "method": "randomURI", "regex": "^random.*"}]};

这个例子中,创建了一个对象,它只包含一个成员“bindings”。“bindings”是一个包含了3个对象的数组,而这每个对象都有"ircEvent""method""regex"3个成员。

这些成员可以用“.”或subscript 操作得到。

myJSONObject.bindings[0].method    // "newURI"

我们可以使用eval()函数的eval()方法调用JavaScript的编译器把JSON文本转变成对象。因为JSON是JavaScript的一个确切的子集,编译器可以正确地解析JSON文本,然后生成一个对象结构。

var myObject = eval('(' + myJSONtext + ')');

eval函数的执行效率很高。然而,它能够编译、执行任何的JS程序,所以这样会有安全问题。在来源可信的时候才需要使用eval,这通常是服务器提供基础页面和JSON数据的web应用程序中的情形。而很多情况中,来源是不可信的。特别是永远都不要信任客户端。

如果关心安全的话,那最好是使用JSON解析器了(js脚本中有解析功能的函数)。JSON解析器只认可JSON文本,因此它比较安全:

var myObject = myJSONtext.parseJSON();

而JSON的字符串转换器(stringifier)则作相反的工作,它将JavaScript数据结构转换为JSON文本。JSON是不支持循环数据结构的,所以注意不能把循环的结构交给字符串转换器。

var myJSONText = myObject.toJSONString();

这里是JSON官方网站提供的一个开源的JSON解析器和字符串转换器:

 一个使用json.js的简单例子

  1. 在VS中新建一个空网站。
  2. 引入json.js文件。
    • <
      script type
      =
      "
      text/javascript
      "
       src
      =
      "
      json.js
      "
      ></
      script
      >
  3. 然后添加一个HTML页面,在页面上拖放两个Textarea和三个Button;Button的ID分别为btnParser、btnEval和btnStringifier;Textarea的ID分别为txtJSON和txtJS,cols设为50,rows设为10;
  4. 编写三个Button的事件代码。
    •     
      <
      script type
      =
      "
      text/javascript
      "
      >
          
      //
      <![CDATA[
          
      ExpandedBlockStart.gifContractedBlock.gif        
      function
       btnStringifier_Click() 
      {
                  
      var oTxtJSON = document.getElementById("txtJSON");           
                  
      var myObject = new Object(); //创建对象
                  var obindings = new Array();
                  
      var oFirst = new Object();
                  
      var oSecond = new Object();
                  
      var oThird = new Object();
                  
                  oFirst.ircEvent 
      = "PRIVMSG";
                  oFirst.method 
      = "newURI";
                  oFirst.regex 
      = "^http://.*";   
                  
      //
                  
                  obindings[
      0= oFirst;
                  obindings[
      1= oSecond;
                  obindings[
      2= oThird;
                  
                  
      //将obindings数组设置为myObject的bindings成员
                  myObject.bindings = obindings;
                  
                  
      //将对象转化成JSON文本,并把文本写入Textarea中
                  oTxtJSON.value = myObject.toJSONString(); 
              }
       
          
      ExpandedBlockStart.gifContractedBlock.gif        
      function
       btnParser_Click() 
      {
                  
      var oTxtJSON = document.getElementById("txtJSON");
                  
      var oTxtJS = document.getElementById("txtJS");
                  
      //把JSON文本转变成对象 
                  var myObject = oTxtJSON.value.parseJSON();
                  
                  
      //获取myObject对象的第一个bindings成员得ircEvent成员(属性值)
                  oTxtJS.value += myObject.bindings[0].ircEvent + "/";
              }
       
      ExpandedBlockStart.gifContractedBlock.gif        
      function
       btnEval_Click() 
                  
      var oTxtJSON = document.getElementById("txtJSON");
                  
      var oTxtJS = document.getElementById("txtJS");
                  
      //把JSON文本转变成对象 
                  var myObject = eval('(' + oTxtJSON.value + ')');
                  
                  
      //获取myObject对象的第一个bindings成员得ircEvent成员(属性值)
                  oTxtJS.value += myObject.bindings[0].method + "/";
              }
          
      //
      ]]> 
          
      </
      script
      >
  5. 运行HTML页面,先点Stringifier,得到对象的JSON文本;然后点Parser,将JSON文本转化成对象,然后获取ircEvent成员的值;最后点Eval,它也将JSON文本转化成对象,然后获取method成员的值;看看效果:

转载于:https://www.cnblogs.com/ringwang/archive/2011/01/22/1942237.html

你可能感兴趣的文章
IdentityServer4-用EF配置Client(一)
查看>>
WPF中实现多选ComboBox控件
查看>>
读构建之法第四章第十七章有感
查看>>
Windows Phone开发(4):框架和页 转:http://blog.csdn.net/tcjiaan/article/details/7263146
查看>>
Unity3D研究院之打开Activity与调用JAVA代码传递参数(十八)【转】
查看>>
python asyncio 异步实现mongodb数据转xls文件
查看>>
TestNG入门
查看>>
【ul开发攻略】HTML5/CSS3菜单代码 阴影+发光+圆角
查看>>
IOS-图片操作集合
查看>>
IO—》Properties类&序列化流与反序列化流
查看>>
测试计划
查看>>
Mysql与Oracle 的对比
查看>>
jquery实现限制textarea输入字数
查看>>
Codeforces 719B Anatoly and Cockroaches
查看>>
jenkins常用插件汇总
查看>>
c# 泛型+反射
查看>>
第九章 前后查找
查看>>
Python学习资料
查看>>
jQuery 自定义函数
查看>>
jquery datagrid 后台获取datatable处理成正确的json字符串
查看>>