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. JavaScript面向对象轻松入门之封装(demo by ES5、ES6、TypeScript)

    本章默认大家已经看过作者的前一篇文章 <JavaScript面向对象轻松入门之抽象> 为什么要封装? 封装(Encapsulation)就是把对象的内部属性和方法隐藏起来,外部代码访问该对 ...

  2. 【转载】Windows系统下删除ubuntu

    原始日期:2013-11-02 15:51 以windows7为例:   用MbrFix.exe修复MBR 卸载Windows/Linux双系统中的Ubuntu1.如果你有Windows系统安装盘/启 ...

  3. ASP.NET MVC5(五):身份验证、授权

    使用Authorize特性进行身份验证 通常情况下,应用程序都是要求用户登录系统之后才能访问某些特定的部分.在ASP.NET MVC中,可以通过使用Authorize特性来实现,甚至可以对整个应用程序 ...

  4. 初学MySQL

    MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品.   Mysql默认端口号: 3306 超级用户:root   prompt 修改提示符. ( ...

  5. js中的匿名函数自执行

    随笔,java中因为有修饰符的存在,那就有private类的存在,js不一样,没有修饰词一说,因此为了防止全局变量的污染,js中就出现了匿名函数,直接上code,看到的人可以自己体会: (functi ...

  6. js调试模式控制台输出信息

    js调试模式控制台输出信息.console.log

  7. Jquery Ajax 保存

    Jquery Ajax 保存: $.ajax({ type: "POST", async:false, url: "${ctx}/url", data: {pI ...

  8. php后台模板html拼接写法

    public function get_kefu_reply_list(){ $wid=$this->_post('order_id'); if(!$wid){ echo('工单信息获取失败!' ...

  9. [命令行] curl查询公网出口IP

    转载:http://blog.csdn.net/orangleliu/article/details/51994513 不管是在家里还是办公室,或者是公司的主机,很多时候都是在内网中,也就是说很多都是 ...

  10. tab切换实现方式1

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