AJAX淺析數據交換的實現
基於JSON的數據交換
前端
前端接收到來自後端的JSON格式的字符串以後,需要將字符串轉換為JSON對象:
var jsonStr = "{\"username\" : \"zhangsan\", \"password\" : \"1233344\"}" // 第一種方法 var jsonObj = JSON.parse(jsonStr) // 第二種方法 var jsonObj = eval('(' + jsonStr + ')')
第二種方法中加括號的原因是:
加圓括號的目的是迫使eval函數在處理JavaScript代碼的時候強制將括號內的表達式(expression)轉化為對象,而不是作為語句(statement)來執行。舉一個例子,例如對象字面量{},如若不加外層的括號,那麼eval會將大括號識別為JavaScript代碼塊的開始和結束標記,那麼{}將會被認為是執行瞭一句空語句。
後端
後端需要將需要傳給前端的數據拼接成JSON格式的字符串。一個一個拼接太麻煩,我們選擇使用阿裡巴巴的fastjson組件,它可以將java對象轉換成json格式的字符串
List<Student> studentList = new ArrayList<>(); while (rs.next()) { // 取出數據 String name = rs.getString("name"); int age = rs.getInt("age"); String addr = rs.getString("addr"); // 將以上數據封裝成Student對象 Student s = new Student(name, age, addr); // 將Student對象放到List集合 studentList.add(s); } // 將List集合轉換成json字符串 jsonStr = JSON.toJSONString(studentList); // 響應JSON格式的字符串給前端。 out.print(jsonStr);
基於XML的數據交換
前端
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>使用XML完成數據交換</title> </head> <body> <script type="text/javascript"> window.onload = function(){ document.getElementById("btn").onclick = function(){ // 1.創建XMLHTTPRequest對象 var xhr = new XMLHttpRequest(); // 2.註冊回調函數 xhr.onreadystatechange = function () { if (this.readyState == 4) { if (this.status == 200) { // 使用XMLHTTPRequest對象的responseXML屬性,接收返回之後,可以自動封裝成document對象(文檔對象) var xmlDoc = this.responseXML //console.log(xmlDoc) // 獲取所有的<student>元素,返回瞭多個對象,應該是數組。 var students = xmlDoc.getElementsByTagName("student") //console.log(students[0].nodeName) var html = ""; for (var i = 0; i < students.length; i++) { var student = students[i] // 獲取<student>元素下的所有子元素 html += "<tr>" html += "<td>"+(i+1)+"</td>" var nameOrAge = student.childNodes for (var j = 0; j < nameOrAge.length; j++) { var node = nameOrAge[j] if (node.nodeName == "name") { //console.log("name = " + node.textContent) html += "<td>"+node.textContent+"</td>" } if (node.nodeName == "age") { //console.log("age = " + node.textContent) html += "<td>"+node.textContent+"</td>" } } html += "</tr>" } document.getElementById("stutbody").innerHTML = html }else{ alert(this.status) } } } // 3.開啟通道 xhr.open("GET", "/ajax/ajaxrequest6?t=" + new Date().getTime(), true) // 4.發送請求 xhr.send() } } </script> <button id="btn">顯示學生列表</button> <table width="500px" border="1px"> <thead> <tr> <th>序號</th> <th>姓名</th> <th>年齡</th> </tr> </thead> <tbody id="stutbody"> <!--<tr> <td>1</td> <td>zhangsan</td> <td>20</td> </tr> <tr> <td>2</td> <td>lisi</td> <td>22</td> </tr>--> </tbody> </table> </body> </html>
這裡要註意,我們接受XML數據的方式不再是調用XMLHttpRequest對象的responseText屬性,而是調用responseXML屬性。
然後再通過getElementsByTagName方法獲得標簽進行遍歷拼接。
後端
如果服務器響應的是XML數據的話,那麼Servlet中的
response.setContentType("text/html;charset=UTF-8");
需要換成
response.setContentType("text/xml;charset=UTF-8");
至於XML數據字符串串的拼接這裡不贅述瞭。
亂碼問題
對於tomcat10來說,關於字符集,我們程序員不需要幹涉,不會出現亂碼。
對於tomcat9及以下版本來說呢?
響應中文的時候,會出現亂碼,怎麼解決?
response.setContentType("text/html;charset=UTF-8");
發送ajax post請求的時候,發送給服務器的數據,服務器接收之後亂碼,怎麼解決?
request.setCharacterEncoding("UTF-8");
到此這篇關於AJAX淺析數據交換的實現的文章就介紹到這瞭,更多相關AJAX數據交換內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Ajax內部交流文檔284278分享
- jQuery中ajax的相關知識點匯總
- Ajax異步請求的五個步驟及實戰案例
- 深入淺析同源與跨域,jsonp(函數封裝),CORS原理
- 面試必備之ajax原始請求