標籤:代碼 cti http val 使用 伺服器 replace s函數 .net
第一種方式:
使用js函數eval();
testJson=eval(testJson);是錯誤的轉換方式。
正確的轉換方式需要加(): testJson = eval("(" + testJson + ")");
eval()的速度非常快,但是他可以編譯以及執行任何JavaScript程式,所以會存在安全問題。在使用eval()。來源必須是值得信賴的。需要使用更安全的json解析器。在伺服器不嚴格的編碼在json或者如果不嚴格驗證的輸入,就有可能提供無效的json或者載有危險的指令碼,在eval()中執行指令碼,釋放惡意代碼。
function ConvertToJsonForJs() { //var testJson = "{ name: ‘小強‘, age: 16 }";(支援) //var testJson = "{ ‘name‘: ‘小強‘, ‘age‘: 16 }";(支援) var testJson = ‘{ "name": "小強", "age": 16 }‘; //testJson=eval(testJson);//錯誤的轉換方式 testJson = eval("(" + testJson + ")"); alert(testJson.name); }
第二種方式使用jQuery.parseJSON()方法對json的格式要求比較高,必須符合json格式
jquery.parseJSON()
js:代碼
function ConvertToJsonForJq() { var testJson = ‘{ "name": "小強", "age": 16 }‘; //不知道 //‘{ name: "小強", age: 16 }‘ (name 沒有使用雙引號包裹) //"{ ‘name‘: "小強", ‘age‘: 16 }"(name使用單引號) testJson = $.parseJSON(testJson); alert(testJson.name); }
字串(string)轉json