• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

JQuery的Ajax接收后端servlet的数据并处理显示到HTML的方法

武飞扬头像
每天八杯水D
帮助1

根据前面的知识点,我们把后端的返回数据json化,前端ajax接收的数据就是json类型的。json用于数据库时,表中数据每一行就是json数组中的一个数据,一行数据=json [i]

JSON知识点:

JsonObject 

  • 使用大括号 {} 保存对象,一个大括号就是一个jsonObjec对象,这里一个大括号就是一个学生对象。

JsonArray 

  • 中括号 [] 保存数组,数组可以包含多个对象

JsonArray  的数据形式如下:

  1.  
    [
  2.  
    {"sno":"1","sname":"张三","born":"1999-01-01","sex":"男","photo":""},
  3.  
    {"sno":"2","sname":"小红花","born":"1999-01-01","sex":"男","photo":"cpu1.jpg/"},
  4.  
    {"sno":"9","sname":"张五","born":"1999-01-01","sex":"男","photo":"数据库.jpg/"}
  5.  
    ]

 如何对JSON操作???

(一)JQuery中Ajax使用JSONObject、JSONArray

JSONArray中想要操作获取每一个学生对象里面的某一个数据时,使用该  该对象.键的名字  就可以获取到这个数据值 。

举例1:我想获取张三的学号:上面说了使用该对象才能获取该对象的数据,但是从后端传来的json数据上面是三个对象组成的一个jsonarray数组。所以只有先获取到张三对应到jsonarray数组中的下标也就是下标0才能获取张三的学号。即

  1.  
    success:function(json)
  2.  
    {
  3.  
    var sno = json[0].sno
  4.  
    var born = json[0].born
  5.  
    }

举例2:获取张五的性别数据

  1.  
    success:function(json)
  2.  
    {
  3.  
    var sex = json[2].sex
  4.  
    }

js中可以使用object.keys() 直接可以获取指定对象的所有键的名字,并以数组形式保存,以后就可以使用循环来获取每一个键名对应的键值了。

        先讲一讲object.keys()的用法,这个方法的参数是json数组中的任意一个,json[0]  json[3]不管哪一个都可以,使用后就是 object.keys(json[0]) ,这个东西返回的是key键的名字,也就是sno、born这个名字,注意不是得到的value值。

JSONObject中如何获取值???

  1.  
    success:function(re)
  2.  
    {
  3.  
    alert(re.username);
  4.  
    alert(re["username"]);
  5.  
    },


(二)java中使用JSONObject、JSONArray

  1.  
    JSONObject Jsonobject = new JSONObject(); //对象
  2.  
    JSONArray JsonArray = new JSONArray(); //对象数组
  3.  
     
  4.  
    Jsonobject .put("key", "value");//JSONObject对象中添加键值对
  5.  
    Jsonobject .getString("key"); //获取指定键名的值
  6.  
     
  7.  
    JsonArray.add(Jsonobject );//将JSONObject对象添加到Json数组中

一、把数据展示在div中的table中

  1.  
    function JsonDataToTable(div3,json) // 把JSON数组展示在一个table
  2.  
    {
  3.  
    var s1=$("<table border='1px' width='90%' class='table'>");
  4.  
    $("#" div3).append(s1);
  5.  
    //先输出表头,任何json都能通用
  6.  
    var keys0=Object.keys(json[0]);//随便取任意一行,得到键名称列表
  7.  
    // 1、显示表头信息,因为keys0是一个数组,里面保存的是key键的名字
  8.  
    var trHead=$("<tr>");s1.append(trHead);
  9.  
    for(var i=0;i<keys0.length;i )
  10.  
    {
  11.  
    var tdHead=$("<td>" keys0[i] "</td>");trHead.append(tdHead);
  12.  
    }
  13.  
    var trEndHead=$("</tr>");s1.append(trEndHead);
  14.  
     
  15.  
    // 2、显示每行的数据信息,json是一个数组
  16.  
    for(var i=0;i<json.length;i )//处理每行
  17.  
    {
  18.  
    var tr0=$("<tr class='danger'>"); s1.append(tr0);
  19.  
    var keys=Object.keys(json[i]);
  20.  
    //得到每个json的键名,keys数组
  21.  
    for(var j=0;j<keys.length;j )
  22.  
    {
  23.  
    if(json[i][keys[j]]==null)
  24.  
    var td0=$("<td>&nbsp</td>");
  25.  
    else
  26.  
    var td0=$("<td>" json[i][keys[j]] "</td>"); //输出每i行的第j个键值
  27.  
    //json[i][keys[j]],
  28.  
    tr0.append(td0);
  29.  
    }
  30.  
    var trend0=$("</tr>"); s1.append(trend0);
  31.  
    }
  32.  
    var send=$("</table>"); $("#" div3).append(send);
  33.  
    }
学新通

 数据展示在div中的table的效果:

学新通

二、使用字符串的替换方法技术实现从数据库获取到的数据展示到指定的table表中。

这样做的好处:写HTML代码时可以直接一套写下来,不用分开写,分开写很复杂麻烦

stringObject.replace(regexp/substr,replacement)

用 replacement 替换满足regexp/substr条件的内容

RegExp 对象表示正则表达式,它是对字符串执行模式匹配的强大工具。

  1.  
    success: function(json) {
  2.  
    //json.length 直接获取jsonArray中有多少个jsonObject对象
  3.  
    for (let i = 0; i < json.length; i ) {
  4.  
    let tr = '<tr>'
  5.  
    '<td>'
  6.  
    '<input name="cids" value="#{cid}" type="checkbox" class="ckitem" />'
  7.  
    '</td>'
  8.  
    '<td><img src="https://blog.csdn.net/weixin_45947938/article/details/.." class="img-responsive" /></td>'
  9.  
    '<td>#{title}#{msg}</td>'
  10.  
    '<td>¥<span id="price-#{cid}">#{realPrice}</span></td>'
  11.  
    '<td>'
  12.  
    '<input type="button" value="-" class="num-btn" onclick="reduceNum(1)" />'
  13.  
    '<input id="num-#{cid}" type="text" size="2" readonly="readonly" class="num-text" value="#{num}">'
  14.  
    '<input class="num-btn" type="button" value=" " onclick="addNum(#{cid})" />'
  15.  
    '</td>'
  16.  
    '<td>¥<span id="total-price-#{cid}">#{totalPrice}</span></td>'
  17.  
    '<td>'
  18.  
    '<input type="button" onclick="delCartItem(this)" class="cart-del btn btn-default btn-xs" value="删除" />'
  19.  
    '</td>'
  20.  
    '</tr>';
  21.  
     
  22.  
    //意思就是把json中的数据替换掉什么html代码中以#{cid}这种形式的数据
  23.  
    // 正则表达式,/#{cid}/g 以/开头,包含#{cid},以/结尾,g表示执行全局匹配,意思是所有满足的地方都要换内容
  24.  
    tr = tr.replace(/#{cid}/g, list[i].cid);
  25.  
    tr = tr.replace(/#{title}/g, list[i].title);
  26.  
    tr = tr.replace(/#{image}/g, list[i].image);
  27.  
    tr = tr.replace(/#{realPrice}/g, list[i].realPrice);
  28.  
    tr = tr.replace(/#{num}/g, list[i].num);
  29.  
    tr = tr.replace(/#{totalPrice}/g, list[i].realPrice * list[i].num);
  30.  
     
  31.  
    $("#cart-list").append(tr);
  32.  
    }
  33.  
    }
学新通

这里是Ajax如何接收form表单中的数据传到后端servlet中去:

https://blog.csdn.net/weixin_45947938/article/details/124306059学新通https://blog.csdn.net/weixin_45947938/article/details/124306059

这篇好文章是转载于:编程之路

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 编程之路
  • 本文地址: /boutique/detail/tanhgkibaj
系列文章
更多 icon
同类精品
更多 icon
继续加载