返回值是true.另:json對象和字符串的相互轉換javascript
JSON.stringify(obj) 將JSON對象轉爲字符串。
JSON.parse(string) 將字符串轉爲JSON對象格式。
以前本身一直對ajax不是特別的熟悉,因此通常都不多用這個去寫功能,可是最近這個項目中用到了,用ajax異步傳數據,json傳數據這個時候就須要去解析傳過來的數據了,eval()和$.parseJSON()都是能夠解析數據的,可是他們也是有區別的;html
1:安全性java
例:jquery
var str = 'alert(1000.toString())'; web
eval(str); ajax
JSON.parse(str); express
用eval能夠解析,而且會彈出對話框,而用JSON.parse()則解析不了。 其實alert並無什麼壞處,可怕的是若是用惡意用戶在json字符串中注入了向頁面插入木馬連接的腳本,用eval也是能夠操做的,而用JSON.parse()則沒必要擔憂這個問題。json
注意:某些低級的瀏覽器尚不支持JSON.parse()數組
2:JSON.parse()解析的必須是json格式的字符串要不報錯,而eval()則沒有這麼嚴格瀏覽器
這裏「json格式的字符串」是指要求指定的字符串必須符合嚴格的JSON格式,例如:屬性名稱必須加雙引號、字符串值也必須用雙引號。
若是傳入一個格式不"無缺"的JSON字符串將拋出一個JS異常
json的解析方法共有兩種:eval 和 JSON.parse(),如:
var jsonStr= '{"name":"lulu", "sex":"female"}';
var evalJson=eval('('+jsonStr+')');
var jsonParseJson=JSON.parse(jsonStr);
這樣就把json格式的字符串jsonStr轉換成了JSON對象。
可是區別是:
var age = 27;
var jsonStr= '{"name":"lulu", "sex":"female","age":++age}';
eval自己的問題。 因爲json是以」{}」的方式來開始以及結束的,在JS中,它會被當成一個語句塊來處理,因此必須強制性的將它轉換成一種表達式。
加上圓括號的目的是迫使eval函數在處理JavaScript代碼的時候強制將括號內的表達式(expression)轉化爲對象,而不是做爲語句(statement)來執行。舉一個例子,例如對象字面量{},如若不加外層的括號,那麼eval會將大括號識別爲JavaScript代碼塊的開始和結束標記,那麼{}將會被認爲是執行了一句空語句。
var evalJson=eval('('+jsonStr+')'); //不報錯此時age的值是28
var jsonParseJson=JSON.parse(jsonStr);//報錯
注意:最近發現有的時候eval()轉數組的時候不起做用,而後百度查了發現這樣寫就能夠了eval('('+string+')');
$(document).ready(function() { $("#submitBtn").click(function(e) { e.preventDefault(); var obj = $(this); var name = $("input[name='loginname']").val(); var passwd = $("input[name='loginpasswd']").val(); $.ajax({ url : "http://localhost:8080/star/loginCheck/", type : "POST", contentType: "application/json;charset=utf-8", data : JSON.stringify({'name':name,'passwd':passwd}), dataType : "text", success : function(result) { if (result == "success") { obj.parents('form').submit(); } else { } }, error:function(msg){ $(".notice").html('Error:'+msg); } }) return false; }) }); </script>
var strJSON='{"webName":"螞蟻部落","url":"softwhy.com","age":"2"}'; var jsonObj=eval("("+strJSON+")"); console.log(jsonObj.webName);
提示:雖然 eval() 的功能很是強大,但在實際使用中用到它的狀況並很少。 實例 例子 1 在本例中,咱們將在幾個字符串上運用 eval(),並看看返回的結果: <script type="text/javascript"> eval("x=10;y=20;document.write(x*y)") document.write(eval("2+2")) var x=10 document.write(eval(x+17)) </script> 輸出: 200 4 27 例子 2 看一下在其餘狀況中,eval() 返回的結果: eval("2+3") // 返回 5 var myeval = eval; // 可能會拋出 EvalError 異常 myeval("2+3"); // 可能會拋出 EvalError 異常 可使用下面這段代碼來檢測 eval() 的參數是否合法: try { alert("Result:" + eval(prompt("Enter an expression:",""))); } catch(exception) { alert(exception); }
JSON 字符串 與 java 對象的轉換 1. 把java 對象列表轉換爲json對象數組,並轉爲字符串 JSONArray array = JSONArray.fromObject(list); String jsonstr = array.toString(); 2. 把java對象轉換成json對象,並轉化爲字符串 JSONObject object = JSONObject.fromObject(user); Log4jInit.ysulogger.debug(object.toString()); 3.把JSON字符串轉換爲JAVA 對象數組 JSONArray json = JSONArray.fromObject(userStr);//userStr是json字符串 List<User> users= (List<User>)JSONArray.toCollection(json, User.class); 4.把JSON字符串轉換爲JAVA 對象 JSONObject jsonobject = JSONObject.fromObject(jsonStr); User user= (User)JSONObject.toBean(object,User.class);
<script type="text/javascript"> getJson('age'); function getJson(key){ var jsonObj={"name":"傅紅雪","age":"24","profession":"刺客"}; //一、使用eval方法 var eValue=eval('jsonObj.'+key); alert(eValue); //二、遍歷Json串獲取其屬性 for(var item in jsonObj){ if(item==key){ //item 表示Json串中的屬性,如'name' var jValue=jsonObj[item];//key所對應的value alert(jValue); } } //三、直接獲取 alert(jsonObj[''+key+'']); } </script>