日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

AJAX淺析數據交換的實現

瀏覽:317日期:2022-06-12 08:54:09
目錄
  • 基于JSON的數據交換
    • 前端
    • 后端
  • 基于XML的數據交換
    • 前端
    • 后端
  • 亂碼問題

    基于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數據交換內容請搜索以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持!

    標簽: Ajax
    日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
    国产精品主播在线观看| 国产探花一区在线观看| 国产在线|日韩| 日韩欧美1区| 99精品网站| 日韩在线一二三区| 欧美久久亚洲| 欧美香蕉视频| 国产精品婷婷| 欧美一区=区| 日韩av二区在线播放| 黄色欧美在线| 久久久9色精品国产一区二区三区| 久久精品1区| 亚洲美女91| 麻豆一区在线| 午夜精品婷婷| 国产精品日本一区二区不卡视频 | 国产精品99免费看| 亚洲精品乱码| 欧美激情久久久久久久久久久| 精品中文字幕一区二区三区四区| 91精品韩国| 综合一区二区三区| 粉嫩av一区二区三区四区五区 | 一区久久精品| 欧美a级一区二区| 天堂网在线观看国产精品| 国产欧美日韩在线观看视频| 香蕉久久久久久久av网站| 精品一区二区三区的国产在线观看| 欧美日韩一二三四| 高清精品久久| 成人国产精品久久| 久久亚洲黄色| 午夜精品免费| 丁香六月综合| 国产精品一区二区美女视频免费看 | 欧美日韩精品一区二区视频| 欧美日韩一区自拍| 午夜久久美女| 日韩av二区| 国产精品扒开腿做爽爽爽软件| 国产亚洲精品久久久久婷婷瑜伽| 久久电影tv| 美女久久99| 国产精久久久| 国产欧美日本| 日韩av资源网| 日本欧美一区| 日本免费新一区视频| 日本中文字幕视频一区| 好吊一区二区三区| 在线看片不卡| 欧美日韩视频网站| 精品一级视频| 精品视频在线观看网站| 麻豆精品在线播放| 国产在线视频欧美一区| 天堂√中文最新版在线| 日韩久久视频| 亚洲高清成人| 中文国产一区| 亚洲一二av| 日韩精品一区二区三区中文字幕| 亚洲一区欧美| 欧美精品影院| 福利一区和二区| 99精品在线| 亚洲涩涩在线| 黄色av一区| 日韩av一二三| 99久久99久久精品国产片果冰| 日本亚洲视频在线| 激情黄产视频在线免费观看| 中文字幕日韩欧美精品高清在线| 国产精品啊啊啊| 日本午夜精品| 久久久久久久久久久9不雅视频| 日韩福利视频导航| 蜜桃91丨九色丨蝌蚪91桃色| 久久精品亚洲人成影院| 久久99青青| 婷婷亚洲精品| 91精品一区二区三区综合在线爱| 国产伦一区二区三区| 激情五月综合网| 高清av不卡| 日本成人在线网站| 亚洲精品三级| 欧美日韩一视频区二区| 免费一级片91| 蜜臀av一区二区在线免费观看 | 午夜国产精品视频| 日本精品另类| 视频一区日韩精品| 在线一区二区三区视频| 久久亚洲图片| 西西人体一区二区| 黄色成人精品网站| 国产伦精品一区二区三区视频| 日韩精品欧美成人高清一区二区| 欧美伊人影院| 国产欧美日韩精品高清二区综合区| 欧美一区=区三区| 国产日韩视频| 国产精品久久久久毛片大屁完整版| 国产乱论精品| 中文字幕成在线观看| 日本视频在线一区| 国产毛片一区二区三区| 欧美一级二区| 日韩欧美一区二区三区免费看| 亚洲综合日本| 午夜影院一区| 青青草91视频| 五月天激情综合网| 激情综合婷婷| 国产欧美另类| 免费不卡在线视频| 久久97久久97精品免视看秋霞| 日韩精品一区第一页| 亚洲精品**中文毛片| 日韩国产欧美三级| 欧美特黄一区| 日韩精品亚洲专区| 狂野欧美性猛交xxxx| 久久精品av| 精品国产乱码久久久| 日韩精品视频网站| 激情欧美亚洲| 国产一区二区三区亚洲| 国产欧美一级| 国产欧美激情| 美女久久精品| 欧美交a欧美精品喷水| 国产精品久久| 国产精品久久久久久久久久妞妞| 男人操女人的视频在线观看欧美| 欧美日韩国产一区精品一区| 色一区二区三区| 精品午夜久久| 精品久久美女| 久久精品影视| 亚洲一区二区毛片| 日韩**一区毛片| 蜜桃精品视频| 亚洲不卡系列| 国产精品视区| 亚洲+小说+欧美+激情+另类| 亚洲精品高潮| 亚洲久草在线| 91精品福利观看| 国产色噜噜噜91在线精品| 国产精品密蕾丝视频下载| 美女精品视频在线| 成人国产综合| 麻豆精品蜜桃| 日韩中文字幕一区二区高清99| 欧美久久久网站| 久久精品亚洲欧美日韩精品中文字幕| 激情欧美丁香| 另类综合日韩欧美亚洲| 夜夜嗨一区二区| 里番精品3d一二三区| 亚洲欧美视频| 国产精品分类| 亚洲自啪免费| 久久精品国产久精国产| 亚洲在线网站| 四虎8848精品成人免费网站| 亚洲成人二区| 日韩国产一区二| 一区在线观看| 极品av在线| 欧美午夜三级| 亚洲欧美日韩国产一区| 日韩在线综合| 精品国产18久久久久久二百| 亚洲乱码视频| 尤物在线精品| 欧美二三四区| 国产精品99久久免费| 亚洲另类av| 一本色道久久精品| 久久免费大视频| 国产一区调教| 国产精品久久久久久久久久久久久久久| 亚洲综合婷婷| 午夜在线精品| 99在线|亚洲一区二区| 欧美13videosex性极品| 97精品视频在线看| 中文在线а√天堂| 另类专区亚洲| 日韩欧美一区二区三区免费观看| 国产96在线亚洲| 日本少妇一区| 国产亚洲高清视频| 久久高清一区|