JSON(JavaScript Object Notation)是一種輕量級的數據格式,采用完全獨立於語言的文本格式,是理想的數據交換格式。同時,JSON是Javascript原生格式,這意味着在javascript中處理JSON數據不需要任何特殊的API或工具包,而且效率非常高。
JSON的結構如下:
“名稱/值”對的集合(A collection of name/value pairs)。不同的語言中,它被理解为對象(object),紀錄(record),結構(struct),字典(dictionary),哈希表(hash table),有鍵列表(keyed list),或者關聯數組 (associative array)。
值的有序列表(An ordered list of values)。在大部分語言中,它被理解为數組(array)
一個標准的json格式:
{"name":"jifeng","company":"taobao"} 總體而言,json是相對比較容易的理解和使用的,但同時存在很多的陷阱,如果不注意的話很容易掉進去,本文主要就是講訴它容易讓人犯錯的地方。
一、json的的解析方法
json的解析方法共有兩種:1. eval() ; 2.JSON.parse()。具體使用方法如下
var jsonstr = '{"name":"jifeng","company":"taobao"}';//eval functionvar evalJson = eval('(' + jsonstr + ')');// JSON.parse functionvar JSONParseJson = JSON.parse(jsonstr);
既然兩者都能達到解析json的結果,但這兩者有什麼區別呢?我用以下的一個例子來進行說明:
1. 用eval方法:
var parse_json_by_eval = function(str){ return eval('('+str+')');}var value = 1;var jsonstr = '{"name":"jifeng","company":"taobao","value":++value}';var json1 = parse_json_by_eval(jsonstr);console.log(json1);console.log('value: '+ value); 執行結果:
{ name: 'jifeng', company: 'taobao', value: 2 }value: 2 2. 用JSON.parse方法
var parse_json_by_JSON_parse = function(str){ return JSON.parse(str);}value = 1;var jsonstr = '{"name":"jifeng","company":"taobao","value":++value}';var json2 = parse_json_by_JSON_parse(jsonstr);console.log(json2);console.log(value); 執行結果:
不能順利執行,報錯
前者能順利執行,並修改了全局變量value的值,而後者報錯了。從上例就可以明顯地看出,eval在解析字符串時,會執行該字符串中的代碼(這样的後果是相當惡劣的),如上例中,由於用eval解析一個json字符串而造成原先的value的值改變。《高性能Javascript》一書即指出:
警告:關於JSON和eval需要注意的是:在代碼中使用eval是很危險的,特別是用它執行第三方的JSON數據(其中可能包含惡意代碼)時,盡可能使用JSON.parse()方法解析字符串本身。該方法可以捕捉JSON中的語法錯誤,並允許你傳入一個函數,用來過滤或轉換解析結果。如果此方法以備Firfox 3.5 、IE8 及 Safari 4 原生支持。大多數javascript類庫包含的JSON解析代碼會直接調用原生版本,如果沒有原生支持的話,會調用一個略微不那麼強大的非原生版本來處理。
一、'\' 對JSON的影響
由於JSON對象是從字符串解析而來,因此在了解 '\' 對JSON影響之前,我們先來了解 '\' 對字符串的影響。這裏特別要強調的是在javascript中 ' 和 " 在表示字符串時是等價,比如'a' = "a"
眾所周知,由於String數據類型包含轉義字符,比如 '\n'表示換行,'\b'表示空格等,因此用表示 he say “hello” 這個字符串時,需要用 '\' 這個特殊字符來表示,即"he say \"hello \"" 。在chrome的中console.log()即可明顯的看出。
http://dl.iteye.com/upload/attachment/0062/0247/1e643d33-828d-3665-80f7-cb5adaf7b93d.jpg
而JSON.parse()又是對字符串的真實含義進行解析,要表示 \ 必須要用"\\\\"表示,具體見下圖:
http://dl.iteye.com/upload/attachment/0062/0249/dae6c992-ff46-3b6c-8104-af1c6f583271.jpg
在json中出現'\'時,必須萬分小心,這的確是json中最容易出錯的地方
在順便提一個小插曲:當我知道在json解析時需要用"\\\\"時表示"\"時,你用JSON.parse('{"a":"a\\b"}'),竟然沒有報錯,難道我理解錯了,細心的朋友應該看出來了,'\b'本身就是個轉義字符,因此這裏的第一個'\'是用來轉義第二個'\' ,這样字符串就編程'a\b'('\b'是個轉義字符),所以JSON.parse()還是可以順利解析的。
對這個概念還是有點繞的,讀者需要多想想,自己當時也是花了較長的時間來想這個問題。
補充資料:
線上解析json網站:http://json.parser.online.fr/
From:http://www.cnblogs.com/lengyuhong/archive/2012/01/07/2262390.html
JSON的結構如下:
“名稱/值”對的集合(A collection of name/value pairs)。不同的語言中,它被理解为對象(object),紀錄(record),結構(struct),字典(dictionary),哈希表(hash table),有鍵列表(keyed list),或者關聯數組 (associative array)。
值的有序列表(An ordered list of values)。在大部分語言中,它被理解为數組(array)
一個標准的json格式:
{"name":"jifeng","company":"taobao"} 總體而言,json是相對比較容易的理解和使用的,但同時存在很多的陷阱,如果不注意的話很容易掉進去,本文主要就是講訴它容易讓人犯錯的地方。
一、json的的解析方法
json的解析方法共有兩種:1. eval() ; 2.JSON.parse()。具體使用方法如下
var jsonstr = '{"name":"jifeng","company":"taobao"}';//eval functionvar evalJson = eval('(' + jsonstr + ')');// JSON.parse functionvar JSONParseJson = JSON.parse(jsonstr);
既然兩者都能達到解析json的結果,但這兩者有什麼區別呢?我用以下的一個例子來進行說明:
1. 用eval方法:
var parse_json_by_eval = function(str){ return eval('('+str+')');}var value = 1;var jsonstr = '{"name":"jifeng","company":"taobao","value":++value}';var json1 = parse_json_by_eval(jsonstr);console.log(json1);console.log('value: '+ value); 執行結果:
{ name: 'jifeng', company: 'taobao', value: 2 }value: 2 2. 用JSON.parse方法
var parse_json_by_JSON_parse = function(str){ return JSON.parse(str);}value = 1;var jsonstr = '{"name":"jifeng","company":"taobao","value":++value}';var json2 = parse_json_by_JSON_parse(jsonstr);console.log(json2);console.log(value); 執行結果:
不能順利執行,報錯
前者能順利執行,並修改了全局變量value的值,而後者報錯了。從上例就可以明顯地看出,eval在解析字符串時,會執行該字符串中的代碼(這样的後果是相當惡劣的),如上例中,由於用eval解析一個json字符串而造成原先的value的值改變。《高性能Javascript》一書即指出:
警告:關於JSON和eval需要注意的是:在代碼中使用eval是很危險的,特別是用它執行第三方的JSON數據(其中可能包含惡意代碼)時,盡可能使用JSON.parse()方法解析字符串本身。該方法可以捕捉JSON中的語法錯誤,並允許你傳入一個函數,用來過滤或轉換解析結果。如果此方法以備Firfox 3.5 、IE8 及 Safari 4 原生支持。大多數javascript類庫包含的JSON解析代碼會直接調用原生版本,如果沒有原生支持的話,會調用一個略微不那麼強大的非原生版本來處理。
一、'\' 對JSON的影響
由於JSON對象是從字符串解析而來,因此在了解 '\' 對JSON影響之前,我們先來了解 '\' 對字符串的影響。這裏特別要強調的是在javascript中 ' 和 " 在表示字符串時是等價,比如'a' = "a"
眾所周知,由於String數據類型包含轉義字符,比如 '\n'表示換行,'\b'表示空格等,因此用表示 he say “hello” 這個字符串時,需要用 '\' 這個特殊字符來表示,即"he say \"hello \"" 。在chrome的中console.log()即可明顯的看出。
http://dl.iteye.com/upload/attachment/0062/0247/1e643d33-828d-3665-80f7-cb5adaf7b93d.jpg
而JSON.parse()又是對字符串的真實含義進行解析,要表示 \ 必須要用"\\\\"表示,具體見下圖:
http://dl.iteye.com/upload/attachment/0062/0249/dae6c992-ff46-3b6c-8104-af1c6f583271.jpg
在json中出現'\'時,必須萬分小心,這的確是json中最容易出錯的地方
在順便提一個小插曲:當我知道在json解析時需要用"\\\\"時表示"\"時,你用JSON.parse('{"a":"a\\b"}'),竟然沒有報錯,難道我理解錯了,細心的朋友應該看出來了,'\b'本身就是個轉義字符,因此這裏的第一個'\'是用來轉義第二個'\' ,這样字符串就編程'a\b'('\b'是個轉義字符),所以JSON.parse()還是可以順利解析的。
對這個概念還是有點繞的,讀者需要多想想,自己當時也是花了較長的時間來想這個問題。
補充資料:
線上解析json網站:http://json.parser.online.fr/
From:http://www.cnblogs.com/lengyuhong/archive/2012/01/07/2262390.html
发表评论
-
jsp端自动下载并保存图片文件
2011-04-21 23:38 1555JScript code <script languag ... -
iFrame只要竖滚动条,不要横滚动条
2011-04-15 23:22 2385如题,就是在网页中,只显示右侧的垂直滚动条,而不要底部的水平滚 ... -
点击按钮保存网页中指定的图片,利用js实现
2011-04-15 00:50 4309有时候在网页上需要禁用右键菜单,但是需要点击某一按钮保存指定的 ... -
js正则验证
2011-03-31 22:47 770引用网址 http://hi.baidu.com/qui ... -
JavaScript相关文章推荐
2011-03-18 00:27 2832判断js数组包是否包含某个元素 要判断数组中是否包含某个元素 ... -
js 数组array的方法介绍
2011-03-18 00:23 837最近用到了Array就对其 ... -
ie的自动完成功能
2011-03-08 00:10 910<!DOCTYPE HTML PUBLIC " ... -
百度代码搜索,谷歌搜索
2011-03-07 23:55 930<!DOCTYPE HTML PUBLIC " ... -
Javascript的调试利器Firebug使用详解
2011-02-25 23:46 866Javascript的调试利器Firebug使用详解.doc -
IE和Firefox浏览器下javascript、CSS兼容性研究
2011-02-25 21:53 885IE和Firefox浏览器下javascript、CSS兼容性 ... -
JS验证日期时间是否合法
2011-02-17 21:00 1965/^(19|20)\d{2}-(0?\d|1[012])-(0 ... -
正则表达式的JS验证
2011-02-17 20:38 799/判断输入内容是否为空 function IsNull ... -
JS函数 验证日期合法(测试通过)
2011-02-17 20:07 1167<script type="text/java ... -
CSS 制作的三级菜单
2011-02-10 13:11 1068<html> <head> <m ... -
竖向显示,向右弹出的3级层导航菜单特效
2011-02-10 13:08 1450<!DOCTYPE html PUBLIC " ... -
CSS+JS三级滑动菜单
2011-02-10 13:06 1437<html> <head> <t ...
相关推荐
uses recursive descent instead of eval. json_parse_state: This files contains an alternative JSON parse function that uses a state machine instead of eval. cycle.js: This file contains two functions...
本文给大家介绍JSON中key动态设置及JSON.parse和JSON.stringify()的区别讲解,具体详情如下所示: var user_info_json = []; user_info_json[user_info_json.length] = eval('('+ '{'+ id +': '+ value +'}' +...
主要介绍了javascript中JSON.parse()与eval()解析json的区别,详细描述了json格式数据的操作技巧,并结合实例形式对比分析了使用JSON.parse()与eval()解析json的区别,需要的朋友可以参考下
在JavaScript端,可以使用`eval()`或`JSON.parse()`函数将接收到的JSON字符串转换回JavaScript对象,从而继续处理数据。 总结一下,`net.sf.json.JSONObject`库是Java开发中一个实用的工具,它简化了Java和...
主要介绍了JSON在Javascript中的使用以及eval和JSON.parse的区别详细解析,本文对eval()和JSON.parse()的区别介绍的非常详细,需要的朋友可以参考下
(其实将符合json标准的字符串转化为js对象可以用eval,但是eval性能相对差且存在安全隐患(会执行json字符串中的代码),本文仅写JSON) 本文写的是转义字符对JSON.parse方法的影响。 一般来说在JSON.parse的参数...
总结来说,`json.js`是一个针对IE6的JSON兼容库,它实现了JSON.parse和JSON.stringify方法,使得在不支持JSON的旧版浏览器中也能进行JSON数据的序列化和反序列化。这个库的使用极大地扩展了JSON在旧浏览器中的适用性...
JSON.parse()、JSON.stringify()和eval()是JavaScript中处理数据和字符串的三个重要函数,每个都有其特定的用途和优势。下面将详细探讨这三个函数的作用。 首先,JSON.parse()是用于将JSON格式的字符串转换成...
**JSON.parse与eval** 在JavaScript中,解析JSON字符串有多种方式。`JSON.parse()` 是安全的解析方法,它可以将JSON字符串转换为JavaScript对象: ```javascript let jsonString = '{"name":"John", "age":30}'; ...
JSON.parse()是JavaScript中的一个内置函数,用于将一个JSON格式的字符串解析成JavaScript对象。这个方法在处理数据交换,特别是与服务器进行异步通信(AJAX)时非常常见。了解和熟练使用JSON.parse()对于任何...
另外,有时候我们可能遇到一些老的代码或者非标准的JSON格式,可能会使用`eval()`函数来解析JSON字符串,但这不推荐,因为`eval()`有安全风险且性能较低。除非必要,否则应优先使用`JSON.parse()`。 总结来说,...
最常用的是使用 `eval()` 函数和内置的 `JSON.parse()` 方法。 ##### 使用 `eval()` 函数 `eval()` 函数可以直接将字符串形式的JSON转换为JavaScript对象。例如: ```javascript var myJSONtext = '{"bindings": ...
字符串化是eval作为JSON.stringify是JSON.parse 。 安装 npm install javascript-stringify --save 用法 import { stringify } from "javascript-stringify" ; 该API与JSON.stringify类似: value转换为字符串的...
总的来说,虽然`eval()`和`new Function()`在某些场景下能快速解析JSON,但为了代码的安全性和性能考虑,推荐使用`JSON.parse()`。在实际开发中,应当遵循最佳实践,避免使用可能导致安全问题的`eval()`。
在JavaScript编程中,将字符串转换为JSON对象是一个常见的任务,特别是在处理服务器与客户端之间的数据交换时。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它采用完全独立于语言的文本格式,但...