您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關ajax獲取json數據為undefined的示例分析的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
Asynchronous JavaScript and XML (Ajax ) 是驅動新一代 Web 站點(流行術語為 Web 2.0 站點)的關鍵技術。Ajax 允許在不干擾 Web 應用程序的顯示和行為的情況下在后臺進行數據檢索。使用 XMLHttpRequest 函數獲取數據,它是一種 API,允許客戶端 JavaScript 通過 HTTP 連接到遠程服務器。Ajax 也是許多 mashup 的驅動力,它可將來自多個地方的內容集成為單一 Web 應用程序。
一般處理服務器傳來的json值時,我們都會用兩種方式進行處理:
1.一種為使用eval()函數。var dataObj=eval("("+data+")");
//轉換為json對象(注:data為json數據);
2. 使用Function對象來進行返回解析。var json =(new Function("","return "+data))();
但是今天做項目(項目用struts2)時用這兩種方法進行json讀取,輸出時一直是undefined。上網查了許多資料,大多都說不明白,后來查到一篇文章作者也遇到這種情況,他解決的辦法是在action中將返回值聲明json屬性,在自己的項目上測試后不通過,后來解決的辦法是再轉一次。以下是自己的思考:從后臺傳來的數據雖然聲明為json屬性,但是傳到前臺時其實還是一個字符串,不是一個json對象,這時候我們需要對后臺的數據進行處理,轉化為json對象,然后獲取json中的值。但是有時候后臺傳來的值不一定是標準的json格式的字符串,雖然我們通過前面的兩種方法之一轉化后臺傳來的對象,但是這時候轉化的json對象實際上還是一個字符串,是一個標準的json字符串,我們再一次轉換后就成了一個json對象。
以下是部分代碼:
result = JSONObject.fromObject(map).toString();//后臺代碼,將map轉成json對象 success : function(result) {//前臺返回值代碼 var obj = eval("("+result+")"); //var data1 =(new Function("","return "+obj))(); var data1=eval("("+obj+")"); alert(data1.name); }
ajax是一種在無需重新加載整個網頁的情況下,能夠更新部分網頁的技術,可以通過在后臺與服務器進行少量數據交換,使網頁實現異步更新。
感謝各位的閱讀!關于“ajax獲取json數據為undefined的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。