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元素操作-创建|数据填充|重置|隐藏行的更多相关文章

  1. CVPixelBuffer的创建 数据填充 以及数据读取

    CVPixelBuffer的创建数据填充以及数据读取 CVPixelBuffer 在音视频编解码以及图像处理过程中应用广泛,有时需要读取内部数据,很少的时候需要自行创建并填充数据,下面简单叙述. 创建 ...

  2. jquery在元素中存储数据:data()

    转自:http://www.php.cn/js-tutorial-405445.html 在元素中存储数据:data() 1 2 3 4 5 6 7 8 9 10 <!DOCTYPE html& ...

  3. 深度解析JQuery Dom元素操作技巧

    深度解析JQuery Dom元素操作技巧 DOM是一种与浏览器.平台.语言无关的接口,使用该接口可以轻松访问页面中所有的标准组件,这篇文章给大家介绍了JQuery dom元素操作方法,写的十分的全面细 ...

  4. 11.-ORM-基本操作-创建数据

    一.ORM-操作 基本操作包括增删改查,即(CRUD)操作 CRUD是指在做计算处理时增加(create).读取查询(read).更新(update).删除(delete) ORM CRUD 核心 - ...

  5. jquery Table基础操作

    鼠标移动行变色     $("#table1 tr").hover(function(){          $(this).children("td").ad ...

  6. jQuery之元素操作及事件绑定

    1.操作元素之属性: ①attr读:("selector").attr("属性名"):=>getAttribute("属性名"):改: ...

  7. BootStrap的table技术小结:数据填充、分页、列宽可拖动

    本文结构:先说明,后代码.拷贝可直接运行. 一.demo结构: 二.文件引入 这些里面除了下面2个比较难找,其他的都很好找 bootstrap-table-resizable.js colResiza ...

  8. 测开之路一百零二:jquery元素操作

    jquery对元素操作,获取/替换文本(.text()).html(.html()).属性(.attr()).值(.val()) html代码 text() 根据标签获取文本值 同一个标签下筛选明细 ...

  9. JQuery之DOM操作及常用函数

    属性操作 attr(name)获取属性值 var imgSrc = $("img").attr("src") attr(name,value)设置属性值 $(& ...

随机推荐

  1. springMVC 配置和使用

    springMVC相对于Struts2学习难度较为简单,并且更加灵活轻便. 第一步:导入jar包 spring.jar.spring-webmvc.jar.commons-logging.jar.sp ...

  2. 关系数据标准语言SQL之数据查询

    数据查询是数据库的核心操作.SQL提供了SELECT语句进行数据查询,该语句具有灵活的使用方式和丰富的功能. 其一般格式为 select [all | distinct]<目标表达式>[, ...

  3. 流畅的python学习笔记:第五章

    在python中一切都可以视作为对象,包括函数.我们来看个例子: def function_try():     '''it is funciton try doc'''     print 'fun ...

  4. Linux网络编程“惊群”问题总结

    1.前言 我从事Linux系统下网络开发将近4年了,经常还是遇到一些问题,只是知其然而不知其所以然,有时候和其他人交流,搞得非常尴尬.如今计算机都是多核了,网络编程框架也逐步丰富多了,我所知道的有多进 ...

  5. [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 ...

  6. AngularJS数据双向绑定

    <body ng-app> <div ng-controller="myCtrl"> <input ng-model="abc" ...

  7. tab切换实现方式2

    tab切换实现方式2: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...

  8. asp.net core 中灵活的配置方式

    asp.net core支持外部文件和命令行参数方式来配置系统运行所需要的配置信息,我们从下面两个常用场景来具体说下具体使用方法. 一.监听地址及端口配置 1,命令行方式 asp.net core系统 ...

  9. Lua性能优化

    原文:Lua Performance Tips 偶然找到<Lua Performance Tips>这篇关于Lua的优化文章,个人认为相较于多数泛泛而谈要好不少.尽管Lua已经到5.2版本 ...

  10. AngularJs学习笔记1——总体介绍

    这周末在家呆了两天,正好中午闲暇时间继续分享Angularjs相关,今天主要分享Angularjs总体介绍及数据绑定部分内容,下面直接进入主题. 1.基本概念: AngularJS是为了克服HTML在 ...