Jquery table元素操作-创建|数据填充|重置|隐藏行
1.Jquery创建表格
/**
* 创建表格
* @param label 标题 json格式,数据结构见附录1
* @param data 数据 json格式,数据结构见附录1
* @param parentElement html元素,表格插入至此元素中
*/
function createTable(label, data, parentElement) {
//创建表格
var table = $("<table> </table>");
//也可以为元素对象设定id,class等属性.
/*var table = $("<table>",{
"id" : "tableId",
"class" : "table_class"
});*/
//设定样式
table.css({
width: "98%",
"border-collapse": "collapse",
border: "0px solid #d0d0d0",
margin: "3px",
"font-size": "14px"
});
//标题行
var tr = $("<tr></tr>");
tr.css({
border: "1px solid #d0d0d0",
height: "30px",
color: "#FFF",
background: "#37b5ad"
});
$.each(label, function (index, value) {
var th = $("<th>" + value + "</th>");
th.appendTo(tr);
});
tr.appendTo(table); $.each(data, function (index, row) {
//数据行
var tr = $("<tr></tr>");
//数据列
$.each(row, function (key, value) {
//console.info(key + ":" + value);
var td = $("<td>" + value + "</td>");
td.css({
border: "1px solid #d0d0d0",
height: "24px"
});
td.appendTo(tr);
});
tr.appendTo(table);
});
table.appendTo(parentElement);
}
createTable
附录 1:label和data的数据结构
//label.json
['事项编码','事项名称'] //data.json
[{"code":"44530200","name":"办理《计划生育情况证明》"},
{"code":"44530200","name":"申请《再生育一胎子女审批》"},
{"code":"44530200","name":"办理《符合政策生育一孩登记》"},
{"code":"44530200","name":"办理《流动人口婚育证明》"}]
2.Jquery填充表格数据
请注意,填充表格数据前提是:已经创建好了html表格行列元素。
/**
*填充表格数据前提是:已经创建好了html表格行列元素。
*
*如:第4行第5列不存在时,会出错。
*表格的html页面示例代码,见附录2.
*/
function fillTableData() {
//table
var table = $("#tableId");
// 也可以通过嵌套了table的元素id获取table对象
// 例如:<div id="contain_table_elementId"><table></table></div>
//var table = $("#contain_table_elementId").find("table"); // row cell 从1开始计数,第1行是表头,这里从第2行开始填充
$("tr:nth-child(2) td:nth-child(2)", table).html('第2行第2列');
$("tr:nth-child(2) td:nth-child(3)", table).html('第2行第3列');
$("tr:nth-child(2) td:nth-child(4)", table).html('第2行第4列');
$("tr:nth-child(2) td:nth-child(5)", table).html('第2行第5列');
//第3行
$("tr:nth-child(3) td:nth-child(2)", table).html('第3行第2列');
$("tr:nth-child(3) td:nth-child(3)", table).html('第3行第3列');
$("tr:nth-child(3) td:nth-child(4)", table).html('第3行第4列');
$("tr:nth-child(3) td:nth-child(5)", table).html('第3行第5列');
//第4行第5列不存在,你猜会发生什么?
//$("tr:nth-child(4) td:nth-child(5)", table).html('第4行第5列'); }
附录2 table.html
<table width="100%" border="0" cellspacing="0" cellpadding="0">
<tr align="center" height="36" class="tr1">
<td class="td1">第1列</td>
<td class="td1">第2列</td>
<td class="td1">第3列</td>
<td class="td1">第4列</td>
<td class="td1">第5列</td>
</tr>
<tr align="center" height="36">
<td>第2行</td>
<!-- td-第2行已创建,你可以为其填充数据 -->
<td></td>
<td></td>
<td ></td>
<td class="td2" ></td>
</tr>
<tr align="center" height="36">
<td>第3行</td>
<td ></td>
<td ></td>
<td ></td>
<td class="td2"></td>
</tr>
</table>
table.html
3.Jquery添加(删除)表格行列
多用于动态表格,即表格的数据行列非固定,ajax填充数据。
注意:因为这里是重置表格,所以删除了除第一行(表头行)的所有行,然后再添加数据行。
//如果不删除原表格table的行row和列cell,那么只会追加新数据行,而不是覆盖。
function rest_table_data() {
var table = $("#tableId");
//删除原有表格行
table.find("tr").each(function(i){
if(i != 0){
//表头不删
this.remove();
}
});
//添加行列数据,table_data.json 见附录3
$.get('table_data.json', function (data) {
// row cell 从1开始,因为明确知道数据是12行,所以i<12
for (var i = 0; i < 12; i++) {
//数据行
var tr = $("<tr>", {
align: "center",
height: "36"
});
//数据列
$.each(data, function (key, value) {
var td = $("<td>" + value[i] + "</td>");
td.appendTo(tr);
if (key == "column_4") {
//这一列的数据,要指定样式
td.attr("class","td2");
}
});
tr.appendTo(table);
}
});
}
附录3 table_data.json
//按列
{"column_1":["1月","2月","3月","4月","5月","6月","7月","8月","9月","10月","11月","12月"],
"column_2":[1858,2120,3466,3513,3829,3035,2934,2761,2576,1635,0,0],
"column_3":[0,0,1,46,86,69,102,82,118,61,0,0],
"column_4":[0,0,0,39,44,59,101,81,101,57,0,0],
"column_5":["0.0%","0.0%","0.0%","85.0%","51.0%","86.0%","99.0%","99.0%","86.0%","93.0%","0.0%","0.0%"]}
4.Jquery隐藏表格行
重点:Jquery隐藏表格行时,要使用<tbody></tbody>标签包裹需要隐藏的<tr></tr>,不然会破坏样式。
Html示例:
<!-- 注意用tbody,不然会破坏表格样式 -->
<tbody id="${rowId}" style="display: none" class="tableRow">
<tr>
<td valign="top" class="title">内容:</td>
<td height="100" valign="top" colspan="4">
<textarea name="option" class="textarea" readonly="readonly">我这行需要隐藏</textarea>
</td>
</tr>
</tbody>
Jquery示例:敬请期待
未完,待续...
Jquery table元素操作-创建|数据填充|重置|隐藏行的更多相关文章
- CVPixelBuffer的创建 数据填充 以及数据读取
CVPixelBuffer的创建数据填充以及数据读取 CVPixelBuffer 在音视频编解码以及图像处理过程中应用广泛,有时需要读取内部数据,很少的时候需要自行创建并填充数据,下面简单叙述. 创建 ...
- jquery在元素中存储数据:data()
转自:http://www.php.cn/js-tutorial-405445.html 在元素中存储数据:data() 1 2 3 4 5 6 7 8 9 10 <!DOCTYPE html& ...
- 深度解析JQuery Dom元素操作技巧
深度解析JQuery Dom元素操作技巧 DOM是一种与浏览器.平台.语言无关的接口,使用该接口可以轻松访问页面中所有的标准组件,这篇文章给大家介绍了JQuery dom元素操作方法,写的十分的全面细 ...
- 11.-ORM-基本操作-创建数据
一.ORM-操作 基本操作包括增删改查,即(CRUD)操作 CRUD是指在做计算处理时增加(create).读取查询(read).更新(update).删除(delete) ORM CRUD 核心 - ...
- jquery Table基础操作
鼠标移动行变色 $("#table1 tr").hover(function(){ $(this).children("td").ad ...
- jQuery之元素操作及事件绑定
1.操作元素之属性: ①attr读:("selector").attr("属性名"):=>getAttribute("属性名"):改: ...
- BootStrap的table技术小结:数据填充、分页、列宽可拖动
本文结构:先说明,后代码.拷贝可直接运行. 一.demo结构: 二.文件引入 这些里面除了下面2个比较难找,其他的都很好找 bootstrap-table-resizable.js colResiza ...
- 测开之路一百零二:jquery元素操作
jquery对元素操作,获取/替换文本(.text()).html(.html()).属性(.attr()).值(.val()) html代码 text() 根据标签获取文本值 同一个标签下筛选明细 ...
- JQuery之DOM操作及常用函数
属性操作 attr(name)获取属性值 var imgSrc = $("img").attr("src") attr(name,value)设置属性值 $(& ...
随机推荐
- springMVC 配置和使用
springMVC相对于Struts2学习难度较为简单,并且更加灵活轻便. 第一步:导入jar包 spring.jar.spring-webmvc.jar.commons-logging.jar.sp ...
- 关系数据标准语言SQL之数据查询
数据查询是数据库的核心操作.SQL提供了SELECT语句进行数据查询,该语句具有灵活的使用方式和丰富的功能. 其一般格式为 select [all | distinct]<目标表达式>[, ...
- 流畅的python学习笔记:第五章
在python中一切都可以视作为对象,包括函数.我们来看个例子: def function_try(): '''it is funciton try doc''' print 'fun ...
- Linux网络编程“惊群”问题总结
1.前言 我从事Linux系统下网络开发将近4年了,经常还是遇到一些问题,只是知其然而不知其所以然,有时候和其他人交流,搞得非常尴尬.如今计算机都是多核了,网络编程框架也逐步丰富多了,我所知道的有多进 ...
- [leetcode-560-Subarray Sum Equals K]
Given an array of integers and an integer k, you need to find the total number of continuous subarra ...
- AngularJS数据双向绑定
<body ng-app> <div ng-controller="myCtrl"> <input ng-model="abc" ...
- tab切换实现方式2
tab切换实现方式2: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...
- asp.net core 中灵活的配置方式
asp.net core支持外部文件和命令行参数方式来配置系统运行所需要的配置信息,我们从下面两个常用场景来具体说下具体使用方法. 一.监听地址及端口配置 1,命令行方式 asp.net core系统 ...
- Lua性能优化
原文:Lua Performance Tips 偶然找到<Lua Performance Tips>这篇关于Lua的优化文章,个人认为相较于多数泛泛而谈要好不少.尽管Lua已经到5.2版本 ...
- AngularJs学习笔记1——总体介绍
这周末在家呆了两天,正好中午闲暇时间继续分享Angularjs相关,今天主要分享Angularjs总体介绍及数据绑定部分内容,下面直接进入主题. 1.基本概念: AngularJS是为了克服HTML在 ...