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

  • Post author:
  • Post category:其他


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

JSON知识点:


JsonObject

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


JsonArray

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

JsonArray  的数据形式如下:

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

如何对JSON操作???

(一)JQuery中Ajax使用JSONObject、JSONArray


JSONArray中

想要操作获取每一个学生对象里面的某一个数据时,使用该


该对象.键的名字


就可以获取到这个数据值 。

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

   success:function(json)
   {
         var sno  = json[0].sno
         var born = json[0].born
    }

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

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

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

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



JSONObject中


如何获取值???

   success:function(re)
   {
          alert(re.username);
          alert(re["username"]);
    },


(二)java中使用JSONObject、JSONArray

JSONObject Jsonobject = new JSONObject();   //对象
JSONArray JsonArray = new JSONArray();   //对象数组

Jsonobject .put("key", "value");//JSONObject对象中添加键值对  
Jsonobject .getString("key"); //获取指定键名的值

JsonArray.add(Jsonobject );//将JSONObject对象添加到Json数组中  

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

function JsonDataToTable(div3,json) // 把JSON数组展示在一个table 
{  
	var s1=$("<table border='1px' width='90%' class='table'>");
		$("#"+div3).append(s1);
		//先输出表头,任何json都能通用
		var keys0=Object.keys(json[0]);//随便取任意一行,得到键名称列表
		// 1、显示表头信息,因为keys0是一个数组,里面保存的是key键的名字
		var trHead=$("<tr>");s1.append(trHead);
		for(var i=0;i<keys0.length;i++)
		{
		 var tdHead=$("<td>"+keys0[i]+"</td>");trHead.append(tdHead);
		}
		var trEndHead=$("</tr>");s1.append(trEndHead);
		
		// 2、显示每行的数据信息,json是一个数组
		for(var i=0;i<json.length;i++)//处理每行
		{ 
		 var tr0=$("<tr class='danger'>"); s1.append(tr0);
		 var keys=Object.keys(json[i]);
		 //得到每个json的键名,keys数组
		 for(var j=0;j<keys.length;j++)
		 {
			 if(json[i][keys[j]]==null)
			var td0=$("<td>&nbsp</td>");
			else
				var td0=$("<td>"+json[i][keys[j]]+"</td>"); //输出每i行的第j个键值
		 //json[i][keys[j]],
		 tr0.append(td0);
		 }   
		 var trend0=$("</tr>"); s1.append(trend0);
		}
		var send=$("</table>");    $("#"+div3).append(send);	
}

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


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

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

stringObject.replace(regexp/substr,replacement)



replacement

替换满足

regexp/substr条件的内容

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

		success: function(json) {
					//json.length  直接获取jsonArray中有多少个jsonObject对象
						for (let i = 0; i < json.length; i++) {
							let tr = '<tr>'
										+ '<td>'
										+ 	'<input name="cids" value="#{cid}" type="checkbox" class="ckitem" />'
										+ '</td>'
										+ '<td><img src="..#{image}collect.png" class="img-responsive" /></td>'
										+ '<td>#{title}#{msg}</td>'
										+ '<td>¥<span id="price-#{cid}">#{realPrice}</span></td>'
										+ '<td>'
										+ 	'<input type="button" value="-" class="num-btn" onclick="reduceNum(1)" />'
										+ 	'<input id="num-#{cid}" type="text" size="2" readonly="readonly" class="num-text" value="#{num}">'
										+ 	'<input class="num-btn" type="button" value="+" onclick="addNum(#{cid})" />'
										+ '</td>'
										+ '<td>¥<span id="total-price-#{cid}">#{totalPrice}</span></td>'
										+ '<td>'
										+ 	'<input type="button" onclick="delCartItem(this)" class="cart-del btn btn-default btn-xs" value="删除" />'
										+ '</td>'
									 + '</tr>';

//意思就是把json中的数据替换掉什么html代码中以#{cid}这种形式的数据
//  正则表达式,/#{cid}/g    以/开头,包含#{cid},以/结尾,g表示执行全局匹配,意思是所有满足的地方都要换内容
							tr = tr.replace(/#{cid}/g, list[i].cid);
							tr = tr.replace(/#{title}/g, list[i].title);
							tr = tr.replace(/#{image}/g, list[i].image);
							tr = tr.replace(/#{realPrice}/g, list[i].realPrice);
							tr = tr.replace(/#{num}/g, list[i].num);
							tr = tr.replace(/#{totalPrice}/g, list[i].realPrice * list[i].num);

							$("#cart-list").append(tr);
						}
					}



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





https://blog.csdn.net/weixin_45947938/article/details/124306059



https://blog.csdn.net/weixin_45947938/article/details/124306059




版权声明:本文为weixin_45947938原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。