js与jQuery实现获取table中的数据并拼成json字符串操作示例
本文实例讲述了js与jQuery实现获取table中的数据并拼成json字符串操作。分享给大家供大家参考,具体如下:
核心代码如下:
JavaScript代码:
functiontabToJSON(id){
vartrs=document.getElementById(id).getElementsByTagName("tr");//获得tr数组
vartitles=trs[0].getElementsByTagName("td");//获得表头td数组
varjson="";
for(vari=1;i
jQuery代码:
functiontabToJSONForJquery(id){
vartitles=$("#"+id).find("tr:firsttd");//获得表头td数组
//遍历非表头的,tr、td...拼装json
varjson="["+$("#"+id).find("tr:not(:first)").map(function(i,e){
return"{"+$(e).children("td").map(function(j,el){
return$(titles[j]).html()+":"+$(el).html();
}).get().join(",")+"}";
}).get().join(",")+"]";
$("#test").html(json);
}
注:为便于测试,建议jQuery直接使用cdn如:
测试HTML部分(table表格与json数据显示部分):
编号 年龄 单元 房间号
1 25 1 1-2
2 22 1 1-1
3 21 3 3-3
4 20 2 2-2
5 35 4 4-2
使用在线HTML/CSS/JavaScript代码运行工具:http://tools.jb51.net/code/HtmlJsRun测试得到json数据为:
[{编号:1,年龄:25,单元:1,房间号:1-2},{编号:2,年龄:22,单元:1,房间号:1-1},{编号:3,年龄:21,单元:3,房间号:3-3},{编号:4,年龄:20,单元:2,房间号:2-2},{编号:5,年龄:35,单元:4,房间号:4-2}]
感兴趣的朋友亲自动手测试一下看看效果如何
PS:这里再为大家推荐几款相关的json在线工具供大家参考:
在线
JSON在线格式化工具:
http://tools.jb51.net/code/jsonformat
在线XML/