js 根据数组分组动态生成table(相同项合并)

<!doctype html public "-//w3c//dtd html 4.01 transitional//en" "http://www.w3.org/tr/html4/loose.dtd">
<html>
<head>
<title> new document </title>
<script>
//xxbh:学校编号,bjbh:班级编号,xx:姓名
var arrjson=[
{‘xxbh‘:‘1001‘,‘bjbh‘:‘0801‘,‘xx‘:‘李四‘},{‘xxbh‘:‘1001‘,‘bjbh‘:‘0802‘,‘xx‘:‘张三‘},
{‘xxbh‘:‘1003‘,‘bjbh‘:‘0803‘,‘xx‘:‘王五‘},{‘xxbh‘:‘1003‘,‘bjbh‘:‘0804‘,‘xx‘:‘晶晶‘},
{‘xxbh‘:‘1005‘,‘bjbh‘:‘0701‘,‘xx‘:‘亮亮‘},{‘xxbh‘:‘1002‘,‘bjbh‘:‘0701‘,‘xx‘:‘明敏‘},
{‘xxbh‘:‘1005‘,‘bjbh‘:‘0701‘,‘xx‘:‘张灿‘},{‘xxbh‘:‘1002‘,‘bjbh‘:‘0801‘,‘xx‘:‘小白‘},
{‘xxbh‘:‘1005‘,‘bjbh‘:‘0802‘,‘xx‘:‘小胖‘},{‘xxbh‘:‘1002‘,‘bjbh‘:‘0901‘,‘xx‘:‘小丽‘},
{‘xxbh‘:‘1003‘,‘bjbh‘:‘0901‘,‘xx‘:‘阿宝‘},{‘xxbh‘:‘1004‘,‘bjbh‘:‘0901‘,‘xx‘:‘王泰‘},
{‘xxbh‘:‘1001‘,‘bjbh‘:‘0901‘,‘xx‘:‘阿毛‘},{‘xxbh‘:‘1006‘,‘bjbh‘:‘0901‘,‘xx‘:‘李铭‘},
{‘xxbh‘:‘1005‘,‘bjbh‘:‘0901‘,‘xx‘:‘阿城‘},{‘xxbh‘:‘1004‘,‘bjbh‘:‘0901‘,‘xx‘:‘张晓‘},
{‘xxbh‘:‘1006‘,‘bjbh‘:‘0901‘,‘xx‘:‘小小‘},{‘xxbh‘:‘1004‘,‘bjbh‘:‘0901‘,‘xx‘:‘白昼‘},
{‘xxbh‘:‘1002‘,‘bjbh‘:‘0901‘,‘xx‘:‘乐乐‘},{‘xxbh‘:‘1001‘,‘bjbh‘:‘0901‘,‘xx‘:‘黎明‘}
];
function creatmapbyxxbh(arrjson){
var xxbhmap={};
var len = arrjson.length;
for(var i=0;i<len;i++){

if(xxbhmap[arrjson[i].xxbh] == undefined){
var list = [];
list.push(arrjson[i]);
xxbhmap[arrjson[i].xxbh] = list;
}else{
xxbhmap[arrjson[i].xxbh].push(arrjson[i]);
}

}
var str="<table border=‘1‘><tr><td width=‘200‘>学校编号</td><td width=‘200‘>班级</td><td width=‘200‘>姓名</td></tr>";
for(var xxbh in xxbhmap){
var stu = xxbhmap[xxbh];
alert(stu.length);
str+="<tr><td rowspan=‘"+stu.length+"‘>"+xxbh+"</td>";
for(var i = 0;i < stu.length;i++){
//document.write(xxbh + " "+stu[i].bjbh+" "+stu[i].xx +"<br />")
//document.write("<table><tr><td>学校编号</td><td>班级</td><td>姓名</td></tr></table> ")
if(i==0){
str+="<td>"+stu[i].bjbh+"</td><td>"+stu[i].xx+"</td></tr>";
}else{
str+="<tr><td>"+stu[i].bjbh+"</td><td>"+stu[i].xx+"</td></tr>";
}
}
str+="<tr ><td colspan=‘3‘>"+xxbh+"共有"+stu.length+"个班级</td></tr>"
}
str+="</table> ";
document.write(str)
}
</script>
</head >
<body>
<button onclick=‘creatmapbyxxbh(arrjson)‘>测试</button>
</body>
</html>

时间: 2024-11-10 13:07:13

js 根据数组分组动态生成table(相同项合并)的相关文章

利用jquery.ajax在jsp页面动态生成table,可以增加修改,并支持一行和多行删除

声明:此为本人原创,只想实现功能,界面样式方面没多考虑,很粗糙能看懂就行--2018-5-14 动态生成table,我利用jsp内嵌java代码从后台获取对象集合,输出的时候有2中方法 1.直接利用java代码for(b1 b:bs)输出 2.利用JSTL标签库的c:foreach输出 不同之处在于,利用c:foreach输出要把获取的对象集合加入到request,然后用${}来读取,而for(b1 b:bs)可以直接输出. 第一种方法--for(b1 b:bs)输出<table id="

动态生成table

需要局部刷新table的数据,就需要使用到js控制生成table: html:table的表头是固定不变的. <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8"> <title>动态生成列表</title> <script src="http://code.jquery.com/jquery-1.9.1

ajax动态生成table

$(function(){ ajaxT();});//ajaxfunction ajaxT(){ $.ajax({ type:"post", dataType"json", data:{code:code}, url:"***.action", success:function(data){ createShowingTable(data) }})}//动态创建一个table function createShowingTable(){ var

tablesorter对于动态生成的table无法使用解决办法

需要对动态生成的table增加搜索功能,发现tablesorter正好满足需求,但动态生成table时,无法使用,发现一个笨办法, 在生成table之前,先写一个静态的<tr></tr>,问题即可解决 <script> $(document).ready(function(){ render_table(){}; $("#myTable").tablesorter({ "theme": "blue", &quo

使用createElement函数来动态创建table的问题

在我们使用ajax时,最重要的就是success函数中对于页面的动态生成,现在的情景就是使用ajax动态生成table或者其他列表格式来进行查询的输出.我去网上查过一些资料,关于动态生成table的例子,大多是通过拼写html文本来实现,这个缺点就是如果数据量很大,js的性能不高.我参考了一些资料后,决定使用动态生成html元素来进行显示.核心函数就是document.createElement(string tagName)来生成table,thead,tbody,tr,th,td等元素.代码

HtmlUnit爬取Ajax动态生成的页面内容

HtmlUnit说白了就是一个浏览器,这个浏览器是用Java写的无界面的浏览器,正因为其没有界面,因此执行的速度还是可以滴. HtmlUnit提供了一系列的API,这些API可以干的功能比较多,如表单的填充,表单的提交,模仿点击链接,由于内置了Rhinojs引擎,因此可以执行JavaScript 之前用的时候一直抓取不了Ajax动态生成table及其数据,用Firefox和IE浏览器查看网页源代码也看不到table和数据,但是用Firefox查看元素能看到信息 调研了HtmlUnit好久都没有用

MVC&amp;JQuery如何根据List动态生成表格

背景:在编码中,常会遇到根据Ajax的结果动态生成Table的情况,本篇进行简要的说明.这已经是我第4.5篇和Ajax有关的随笔了,互相之间有很多交叠的地方,可自行参考. 后台代码如下: 1 public ActionResult Index() 2 { 3 4 return View(); 5 } 6 7 8 public ActionResult GetStus() 9 { 10 List<Stu> ListStu = new List<Stu>(){ 11 new Stu{A

万能js实现翻页,动态生成内容自动翻页,兼容各种浏览器(已测试)----神器版!

转--http://www.2cto.com/kf/201402/277535.html 万能js实现翻页,动态生成内容自动翻页,兼容各种浏览器(已测试)----神器版! 2014-02-11      0个评论    来源:卡布洛技术专栏   收藏    我要投稿 要求:动态输入内容,点击post生成内容条,实现自动翻页! 废话不多说,直接上代码: js代码: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25

JS实现动态生成表格并提交表格数据向后端 表格中数据转为json

原文地址 需求:在web页面上动态的生成表格,并可以对表格中的数据进行编辑,然后把表格中的数据提交至后端服务器保存. 首先动态生成表格. 1.首先我们需要导入JS库文件.jQuery 2.然后在页面div中事先创建一个空白表格,可以根据需求而定,我这里是一个带表头的表格 <table border="0" style="text-align: center;" width="100%" id="myTable">