AJAX淺析數(shù)據(jù)交換的實(shí)現(xiàn)
目錄

基于json的數(shù)據(jù)交換

前端

前端接收到來(lái)自后端的json格式的字符串以后,需要將字符串轉(zhuǎn)換為json對(duì)象:

var jsonstr = "{\"username\" : \"zhangsan\", \"password\" : \"1233344\"}"
// 第一種方法
var jsonobj = json.parse(jsonstr)
// 第二種方法
var jsonobj =  eval('(' + jsonstr + ')')

第二種方法中加括號(hào)的原因是:

加圓括號(hào)的目的是迫使eval函數(shù)在處理javascript代碼的時(shí)候強(qiáng)制將括號(hào)內(nèi)的表達(dá)式(expression)轉(zhuǎn)化為對(duì)象,而不是作為語(yǔ)句(statement)來(lái)執(zhí)行。舉一個(gè)例子,例如對(duì)象字面量{},如若不加外層的括號(hào),那么eval會(huì)將大括號(hào)識(shí)別為javascript代碼塊的開(kāi)始和結(jié)束標(biāo)記,那么{}將會(huì)被認(rèn)為是執(zhí)行了一句空語(yǔ)句。

后端

后端需要將需要傳給前端的數(shù)據(jù)拼接成json格式的字符串。一個(gè)一個(gè)拼接太麻煩,我們選擇使用阿里巴巴的fastjson組件,它可以將java對(duì)象轉(zhuǎn)換成json格式的字符串

list<student> studentlist = new arraylist<>();
while (rs.next()) {
    // 取出數(shù)據(jù)
    string name = rs.getstring("name");
    int age = rs.getint("age");
    string addr = rs.getstring("addr");
    // 將以上數(shù)據(jù)封裝成student對(duì)象
    student s = new student(name, age, addr);
    // 將student對(duì)象放到list集合
    studentlist.add(s);
}
// 將list集合轉(zhuǎn)換成json字符串
jsonstr = json.tojsonstring(studentlist);
// 響應(yīng)json格式的字符串給前端。
 out.print(jsonstr);

基于xml的數(shù)據(jù)交換

前端

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>使用xml完成數(shù)據(jù)交換</title>
</head>
<body>
<script type="text/javascript">
    window.onload = function(){
        document.getelementbyid("btn").onclick = function(){
            // 1.創(chuàng)建xmlhttprequest對(duì)象
            var xhr = new xmlhttprequest();
            // 2.注冊(cè)回調(diào)函數(shù)
            xhr.onreadystatechange = function () {
                if (this.readystate == 4) {
                    if (this.status == 200) {
                        // 使用xmlhttprequest對(duì)象的responsexml屬性,接收返回之后,可以自動(dòng)封裝成document對(duì)象(文檔對(duì)象)
                        var xmldoc = this.responsexml
                        //console.log(xmldoc)
                        // 獲取所有的<student>元素,返回了多個(gè)對(duì)象,應(yīng)該是數(shù)組。
                        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.開(kāi)啟通道
            xhr.open("get", "/ajax/ajaxrequest6?t=" + new date().gettime(), true)
            // 4.發(fā)送請(qǐng)求
            xhr.send()
        }
    }
</script>
<button id="btn">顯示學(xué)生列表</button>
<table width="500px" border="1px">
    <thead>
    <tr>
        <th>序號(hào)</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數(shù)據(jù)的方式不再是調(diào)用xmlhttprequest對(duì)象的responsetext屬性,而是調(diào)用responsexml屬性。

然后再通過(guò)getelementsbytagname方法獲得標(biāo)簽進(jìn)行遍歷拼接。

后端

如果服務(wù)器響應(yīng)的是xml數(shù)據(jù)的話,那么servlet中的

response.setcontenttype("text/html;charset=utf-8");

需要換成

response.setcontenttype("text/xml;charset=utf-8");

至于xml數(shù)據(jù)字符串串的拼接這里不贅述了。

亂碼問(wèn)題

對(duì)于tomcat10來(lái)說(shuō),關(guān)于字符集,我們程序員不需要干涉,不會(huì)出現(xiàn)亂碼。

對(duì)于tomcat9及以下版本來(lái)說(shuō)呢?

響應(yīng)中文的時(shí)候,會(huì)出現(xiàn)亂碼,怎么解決?

response.setcontenttype("text/html;charset=utf-8");

發(fā)送ajax post請(qǐng)求的時(shí)候,發(fā)送給服務(wù)器的數(shù)據(jù),服務(wù)器接收之后亂碼,怎么解決?

request.setcharacterencoding("utf-8");

到此這篇關(guān)于ajax淺析數(shù)據(jù)交換的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)ajax數(shù)據(jù)交換內(nèi)容請(qǐng)搜索碩編程以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持碩編程!

相關(guān)文章
亚洲国产精品第一区二区,久久免费视频77,99V久久综合狠狠综合久久,国产免费久久九九免费视频