Json的适用场景以及和Javascript的关系

Json是什么

JSON是一种轻量级的数据交换格式,全称——JavaScript 对象表示法(JavaScript Object Notation)。

类比XML,你可以把JSON看作是一种存储数据的格式类型,一种数据规范。

描述JSON格式数据的语法采用了JS对象字面量的表示方法,但是你不能的把JS对象就看做是JSON了,同XML一样JSON只是一种存储数据的类型,它是独立于语言存在的,只是在不同的编程语言中对这种数据类型的实现不同,例如在JavaScript中使用JavaScript对象对这种数据格式进行实现,那么在java中当然是用java对象实现。

Json与Javascript的关系

同时,既然JSON这种数据格式用JS对象字面量的表示方法进行描述,那么描述JSON的语法就是JS对象字面量表示法语法的一个子集。如下图所示:


image

其实对于"js对象的字面量表示法"中属性加不加引号是"js对象"还是"JSON对象的说法本身就是错误的,加与不加引号它都是"js对象",只是你加了引号以后,从语法上来说符合JSON的语法规则,而JSON的语法规则又是"js对象的字面量表示法"语法规则的子集,所以无论怎么表示,他都是一个"js对象"。那么有没有属性必须要加引号的情况呢?我们知道js对于变量的命名规则是数字、字母、下划线及$符号,属性不加引号时也符合这个规则,但要是属性中有这四种之外其它的符号如"[" 或者 "."等等,属性就必须引号来表示。

说到底,JSON是一种数据格式,一种对于数据的规范,因为其居有自我描述性及简洁的语法规则,让它成为了一种在不同语言之间理想的数据交换的格式,JSON独立于语言而存在,任何站在语言的角度及对象层面对他的解释都是有局限性或者是错误的。

Json的适用场景

一种是JavaScript原生态的json使用,另外一种是jQuery应用场景下的JSON使用。

  1. 原生态JSON的使用–JSON.stringify(Object)
var jsonOption = [];
                jsonOption.push(optionObj);
                var val = JSON.stringify(jsonOption);
                $.post("ServletA?action=ActionONe",
                        {
                            p1:num,
                            mapValue:val
                        },
                        function(data,status){}

JSON.stringify(object);的使用是为把前端一个Object对象转化为字符串格式,传输到后端。

  1. jQuery中的使用场景–$.parseJSON(JSONString);
function fuctionName(){
                var jsonOption = [];
                jsonOption.push(optionObj);
                var val = JSON.stringify(jsonOption);
                $.post("ServletA?action=ActionOne",
                        {
                            p1:num,
                            mapValue:val
                        },
                        function(data,status){
                            var mynum = $.parseJSON(data);
                            var newNum = mynum["data"];
                            if(newNum){
                            }else{
                            }

主要是使用它来完成从后端接受的JSON字符串转换为Object对象便于在前端来使用它。

你可能感兴趣的:(Json的适用场景以及和Javascript的关系)