在javascript中使用Json

jSON是JavaScript面向对象语法的一个子集。因为JSON是JavaScript的一个子集,所以它可清晰的运用于此语言中。javascript

文本生成json对象,必须在外面加一对括号。java


js 代码
 web

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

在上面的例子中,咱们建立了只包含一个成员 "bindings" 的一个对象,bindings 则包含了一个由3个对象组成的数组。这3个对象都包含3个成员:"ircEvent", "method","regex"。json

在javascript 中, 成员能够经过“点号”来获取。
好比:数组

js 代码浏览器

myJSONObject.bindings[0].method  

经过eval() 函数能够将JSON字符串转化为对象。安全

js 代码服务器

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

eval 函数很是快,可是它能够编译任何 javascirpt 代码,这样的话就可能产生安全的问题。eval 的使用是基于传入的代码参数是可靠的假设的,有一些状况下,可能客户端是不可信任的。数据结构

若是基于安全的考虑的话,最好是使用一个 JSON 解析器。 一个 JSON 解析器将只接受 JSON 文本。因此是更安全的。dom

js 代码
 

var myObject = JSON.parse(myJSONtext, filter);  

可选的 filter 参数将遍历每个value key 值对, 并进行相关的处理。如:


js 代码

myData = JSON.parse(text, function (key, value) {       

return key.indexOf('date') >= 0 ? new Date(value) : value;    }); 

stringifier 函数的做用跟 parse 相反, 用来将一个js对象转换为 JSON 文本。

js 代码
var myJSONText = JSON.stringifier(myObject);


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

上面的示例,建立了一个包括单独成员”bindings”的对象,此成员包括一个含有三个对象(”ircEvent”, “method”, 与 “regex”)的数组

成员能够经过.或者下标操做符检索。

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

为了将JSON文本转换为对象,可使用eval()函数。eval()函数调用JavaScript编辑器。因为JSON是JavaScript的子集,所以编译器将正确的解析文本并产生对象结构。文本必须括在括号中避免产生JavaScript的语法歧义。

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

eval函数很是快速。它能够编译执行任何JavaScript程序,所以产生了安全性问题。当使用可信任与完善的源代码时才可使用eval函数。这样能够更安全的使用JSON解析器。使用XMLHttpRequest的web应用,页面之间的通信只容许同源,所以是能够信任的。但这却不是完善的。若是服务器没有严谨的JSON编码,或者没有严格的输入验证,那么可能传送包括危险脚本的无效JSON文本。eval函数将执行恶意的脚本。

使用JSON解析器能够防止此类事件。JSON解析器只能辨识JSON文本,拒绝全部脚本。提供了本地JSON支持的浏览器的JSON解析器将远快于eval函数。预计将来的ECMAScript标准将支持本地JSON。

var myObject = JSON.parse(myJSONtext, reviver);

一个替换函数(reviver function)作为可选参数被最终结果的每一级的键(key)与值(value)调用。 每一个值都将被替换函数的值代替。这能够用来将通常的类改变成伪类的实例,或者将日期字符串转变为日期对象。

myData = JSON.parse(text, function (key, value) {
    var type;
    if (value && typeof value === 'object') {
        type = value.type;
        if (typeof type === 'string' && typeof window[type] === 'function') {
            return new (window[type])(value);
        }
    }
    return value;
});

JSON stringifier进行反向操做,能够把JavaScript数据结构转换为JSON文本。JSON不支持循环数据结构,所以应当心不要为JSON stringifier提供循环结构。

var myJSONText = JSON.stringify(myObject, replacer);

若是stringify函数发现一个带有toJSON方法的对象,它将执行此方法,而且返回产生的值。这样一个对象就能够决定本身的JSON表现。

stringifier方法能够携带一个可选的字符串数组。这些字符串被用于选择包括在JSON文本中的属性。

stringifier方法能够携带一个可选的替代(replacer)函数。它将在结构中每一个值的toJSON方法(若是有的话)后面执行。它将每一个键与值作为参数传递,固然对象要包含这个键。返回值将被字符串化。

若是没有提供数组或替代函数,一个用于忽略被集成的属性的可选替代函数将被提供。若是想要全部被继承的属性,能够提供一个简单的替换函数:

var myJSONText = JSON.stringify(myObject, function (key, value) {
    return value;
});

对于在JSON中没有表达的值(如函数与undefined)是排除在外的。

不能肯定的数量将被替换为null。为了替代其它的值,能够像下面同样使用替换(replacer)函数

function replacer(key, value) {    if (typeof value === 'number' && !isFinite(value)) {        return String(value);    }    return value;}

相关文章
相关标签/搜索