JavaScript中字符串(string)轉(zhuǎn)json的2種方法
第一種方式:
使用js函數(shù)eval();
testJson=eval(testJson);是錯誤的轉(zhuǎn)換方式。
正確的轉(zhuǎn)換方式需要加(): testJson = eval("(" + testJson + ")");
eval()的速度非???,但是他可以編譯以及執(zhí)行任何javaScript程序,所以會存在安全問題。在使用eval()。來源必須是值得信賴的。需要使用更安全的json解析器。在服務(wù)器不嚴(yán)格的編碼在json或者如果不嚴(yán)格驗證的輸入,就有可能提供無效的json或者載有危險的腳本,在eval()中執(zhí)行腳本,釋放惡意代碼。
js代碼:
function ConvertToJsonForJs() {
//var testJson = "{ name: '小強(qiáng)', age: 16 }";(支持)
//var testJson = "{ 'name': '小強(qiáng)', 'age': 16 }";(支持)
var testJson = '{ "name": "小強(qiáng)", "age": 16 }';
//testJson=eval(testJson);//錯誤的轉(zhuǎn)換方式
testJson = eval("(" + testJson + ")");
alert(testJson.name);
}
第二種方式使用jquery.parseJSON()方法對json的格式要求比較高,必須符合json格式
jquery.parseJSON()
js:代碼
function ConvertToJsonForJq() {
var testJson = '{ "name": "小強(qiáng)", "age": 16 }';
//不知道
//'{ name: "小強(qiáng)", age: 16 }' (name 沒有使用雙引號包裹)
//"{ 'name': "小強(qiáng)", 'age': 16 }"(name使用單引號)
testJson = $.parseJSON(testJson);
alert(testJson.name);
}
相關(guān)文章
JavaScript語言中的Literal Syntax特性分析
JavaScript語言中的Literal Syntax特性分析...2007-03-03
javascript 禁用IE工具欄,導(dǎo)航欄等等實現(xiàn)代碼
在處理問題時候遇到的,就順便記錄與大家一起分享下,感興趣的朋友可以參考下哈,希望可以幫助到你2013-04-04
Bootstrap模態(tài)框插入視頻的實現(xiàn)代碼
這篇文章主要介紹了Bootstrap模態(tài)框插入視頻的實現(xiàn)代碼,需要的朋友可以參考下2017-06-06

