Json概述

来源:互联网 发布:最好拆卸软件 编辑:程序博客网 时间:2024/04/25 16:36

 

什么是JSON

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,易于阅读和编写,同时也易于机器解析和生成。它基于ECMA262语言规范(1999-12第三版)中JavaScript编程语言的一个子集。 JSON采用与编程语言无关的文本格式,但是也使用了类C语言(包括C C++ C# Java JavaScriptPerl Python等)的习惯,这些特性使JSON成为理想的数据交换格式。

JSONXML的比较

  可读性

  JSONXML的可读性可谓不相上下,一边是建议的语法,一边是规范的标签形式,很难分出胜负。

  可扩展性

  XML天生有很好的扩展性,JSON当然也有,没有什么是XML能扩展,JSON不能的。不过JSONJavascript主场作战,可以存储Javascript复合对象,有着xml不可比拟的优势。

  编码难度

  XML有丰富的编码工具,比如Dom4jJDom等,JSON也有json.org提供的工具。无工具的情况下,相信熟练的开发人员一样能很快的写出想要的xml文档和JSON字符串,不过,xml文档要多很多结构上的字符。

JSON定义

   JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,易于阅读和编写,同时也易于机器解析和生成。它基于ECMA262语言规范(1999-12第三版)中JavaScript编程语言的一个子集。 JSON采用与编程语言无关的文本格式,但是也使用了类C语言(包括C C++ C# JavaJavaScript Perl Python等)的习惯,这些特性使JSON成为理想的数据交换格式。

 

JSON的结构基于下面两点

1. "名称/"对的集合 不同语言中,它被理解为对象(object),记录(record),结构(struct),字典(dictionary),哈希表(hash table),键列表(keyed list)

2. 值的有序列表 多数语言中被理解为数组(array)

JSON使用:

JSON以一种特定的字符串形式来表示 JavaScript 对象。如果将具有这样一种形式的字符串赋给任意一个 JavaScript 变量,那么该变量会变成一个对象引用,而这个对象就是字符串所构建出来的,好像有点拗口,我们还是用实例来说明。

按照最简单的形式,可以用下面这样的 JSON 表示名称/值对:

{ "firstName": "Brett" };

这个示例非常基本,而且实际上比等效的纯文本名称/值对占用更多的空间:

firstName = Brett;

但是,当将多个名称/值对串在一起时,JSON 就会体现出它的价值了。首先,可以创建包含多个名称/值对的记录

这里假设我们需要创建一个User对象,并具有以下属性

用户ID

用户名

用户Email

您可以使用以下JSON形式来表示User对象:

{ "UserID": 11, "Name":"Truly", "Email":"zhuleiprohotmail.com" };

然后如果把这一字符串赋予一个JavaScript变量,那么就可以直接使用对象的任一属性了。

完整代码:

<script>

    var User = { "UserID": 11, "Name": "Truly", "Email": "zhuleiprohotmail.com" };

    alert(User.Name);

</script>

实际使用时可能更复杂一点,比如我们为Name定义更详细的结构,使它具有FirstNameLastName

  <script>

        //完整代码:

        var User = { "UserID": 11, "Name": { "FirstName": "Truly", "LastName": "Zhu" }, "Email": "zhuleiprohotmail.com" };

        alert(User.Name.FirstName);

    </script>

现在我们增加一个新的需求,我们某个页面需要一个用户列表,而不仅仅是一个单一的用户信息,那么这里就需要创建一个用户列表数组。

下面代码演示了使用JSON形式定义这个用户列表:

[

{ "UserID": 11, "Name": { "FirstName": "Truly", "LastName": "Zhu" }, "Email": "zhuleiprohotmail.com" },

{ "UserID": 12, "Name": { "FirstName": "Jeffrey", "LastName": "Richter" }, "Email": "xxxxxx.com" },

{ "UserID": 13, "Name": { "FirstName": "Scott", "LastName": "Gu" }, "Email": "xxx2xxx2.com" }

];

 

完整代码:

   <script>

        var UserList = [

{ "UserID": 11, "Name": { "FirstName": "Truly", "LastName": "Zhu" }, "Email": "zhuleiprohotmail.com" },

{ "UserID": 12, "Name": { "FirstName": "Jeffrey", "LastName": "Richter" }, "Email": "xxxxxx.com" },

{ "UserID": 13, "Name": { "FirstName": "Scott", "LastName": "Gu" }, "Email": "xxx2xxx2.com" }

];

        alert(UserList[0].Name.FirstName);

    </script>

 

事实上除了使用"."引用属性外,我们还可以使用下面语句:

alert(UserList[0]["Name"]["FirstName"]);

 //或者

alert(UserList[0].Name["FirstName"]);

 

json的修改:

UserList.UserID[0] = "01"

 

在将字符串转换为 JavaScript 对象之后,就可以像这样修改变量中的数据。

完整事例:

function jsontest() {

       //json

       var jsontext = '{"person":{"weight":"75kg","age":"24"},"num":["1","2","3","4"]}';

       //解析json

       var obj = eval("(" + jsontext + ")"); //通过eval() 函数可以将JSON字符串转化为对象。

       //var jsontext = jsontext.parseJSON();   //第二种转换

       //取出json中的信息

       alert(obj.person.weight);

  }

 

现在读者应该对JSON的使用有点认识了,归纳为以下几点:

 

1.对象是属性、值对的集合。一个对象的开始于“{”,结束于“}”。每一个属性名和值间用“:”提示,属性间用“,”分隔。

2.数组是有顺序的值的集合。一个数组开始于"[",结束于"]",值之间用","分隔。

3.值可以是引号里的字符串、数字、truefalsenull,也可以是对象或数组。这些结构都能嵌套。

4.字符串和数字的定义和C#Java基本一致。

 

Json应用

<script type="text/javascript">

        var Person = {

            Name: 'TerryLee',

            Age: 25

        };

        function myObject() {

            return Person;

        }

 </script>

 

  public class Person

    {

        public String Name { get; set; }

        public int Age { get; set; }

    }

 

void btnInvoke_Click(object sender, RoutedEventArgs e)

    {

        ScriptObject script = HtmlPage.Window.Invoke("myObject", null) as ScriptObject;

        Person person = script.ConvertTo<Person>();

        this.tblStatus.Text =String.Format(@"这里是JavaScript中的JSON对象,Name={0}Age={1}",person.Name,

        person.Age.ToString());

    }

 

 

 

原创粉丝点击