• JSON基础


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

    JSON建构于两种结构:

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

    值的有序列表(An ordered list of values)。在大部分语言中,它被理解为数组(array)。

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

    JSON具有以下这些形式:

    对象是一个无序的“‘名称/值’对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值’ 对”之间使用“,”(逗号)分隔。

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

    值(value)可以是双引号括起来的字符串(string)、数值(number)、truefalsenull、对象(object)或者数组(array)。这些结构可以嵌套。

    字符串(string)是由双引号包围的任意数量Unicode字符的集合,使用反斜线转义。一个字符(character)即一个单独的字符串(character string)。

    字符串(string)与C或者Java的字符串非常相似。

    数值(number)也与C或者Java的数值非常相似。除去未曾使用的八进制与十六进制格式。除去一些编码细节。

    空白可以加入到任何符号之间。 以下描述了完整的语言。

    JSON举例(javascript中使用json):

    先来个最简单的:

    1  <script type="text/javascript">
    2             var user = {"Id":1,"Name":"Hubery","Age":23,"Email":"hubery@163.com"};
    3             alert(user.Id); //这样访问也没问题alert(user["Id"]);
    4             alert(user.Name);
    5             alert(user.Age);
    6             alert(user.Email);
    7     </script>

    我们添加Address属性,定义更细的用户信息结构:

     1     <script type="text/javascript">
     2     var user = 
     3               {
     4                 "Id":1,
     5                 "Name":"Hubery",
     6                 "Age":23,
     7                 "Address":
     8                   {
     9                       "City":"Beijing","ZipCode":"111111"
    10                   },
    11                 "Email":"hubery@163.com"
    12               };
    13               
    14               alert(user.Id);
    15               alert(user.Name);
    16               alert(user.Age);
    17               alert(user.Address.City);
    18               alert(user.Address.ZipCode);
    19               alert(user.Email);
    20     </script>

    下面我们把Address属性定义成数组,用户有两个Address:

     1     <script type="text/javascript">
     2     var user = 
     3               {
     4                 "Id":1,
     5                 "Name":"Hubery",
     6                 "Age":23,
     7                 "Address":
     8                   [
     9                     {"City":"Beijing","ZipCode":"111111"},
    10                     {"City":"Langfang","ZipCode":"222222"}
    11                   ],
    12                 "Email":"hubery@163.com"
    13               };
    14               
    15               alert(user.Id);
    16               alert(user.Name);
    17               alert(user.Age);
    18               alert(user.Address[0].City);//还可以这样:alert(user.Address[0]["City"]);
    19               alert(user.Address[0].ZipCode);
    20               alert(user.Address[1].City);
    21               alert(user.Address[1].ZipCode);
    22               alert(user.Email);
    23     </script>

    如果我们想要一个用户列表,能行吗?答案是,没问题!

     1     <script type="text/javascript">
     2     var user = 
     3               [
     4                   {
     5                     "Id":1,
     6                     "Name":"Hubery",
     7                     "Age":23,
     8                     "Address":
     9                       [
    10                         {"City":"Beijing","ZipCode":"111111"},
    11                         {"City":"Langfang","ZipCode":"222222"}
    12                       ],
    13                     "Email":"hubery@163.com"
    14                   },
    15                   {
    16                     "Id":2,
    17                     "Name":"Chris",
    18                     "Age":24,
    19                     "Address":{"City":"Beijing","ZipCode":"100085"},
    20                     "Email":"chris@163.com"
    21                   }
    22               ]
    23               
    24               alert("Id: "+user[0].Id+"/r/nName: "+
    25               user[0].Name+"/r/nAge: "+
    26               user[0].Age+"/r/nAddress: ("+
    27               user[0].Address[0].City+","+user[0].Address[0].ZipCode+") ("+user[0].Address[1].City+","+user[0].Address[1].ZipCode+")/r/nEmail: "+
    28               user[0].Email);
    29               
    30               alert("Id: "+user[1].Id+"/r/nName: "+
    31               user[1].Name+"/r/nAge: "+
    32               user[1].Age+"/r/nAddress: ("+
    33               user[1].Address.City+","+user[1].Address.ZipCode+")/r/nEmail: "+
    34               user[1].Email);
    35     </script>
  • 相关阅读:
    WPF数据绑定之Ado.net的数据库连接绑定
    asp.net 网站js弹出提示后原页面css样式丢失
    Javascript中函数重载的实现
    JavaScript的继承
    WPF数据绑定之4种绑定模式
    Asp.net输出Excel文件并且下载该文件以及某些细节问题解决
    js 验证身份证 带X
    WPF的数据绑定之控件源绑定以及代码方式绑定
    WPF数据绑定之DataContext
    在无cookie模式中,会话话状态的ID将会自动保存在ASP.NET的查询字符串中
  • 原文地址:https://www.cnblogs.com/sunran/p/4031111.html
Copyright © 2020-2023  润新知