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)设置属性值 $(& ...
随机推荐
- mysql too many connections 问题
我的处理步骤: 第一步:首次确定你的服务可不可以重启,如果可以重启转第二步,如果不可以重启转第三步,这个主要考虑已经部署到客户现场或者正在使用中的数据库不能重启. 第二步:查找mysql的安装路径,这 ...
- [python]-数据科学库Numpy学习
一.Numpy简介: Python中用列表(list)保存一组值,可以用来当作数组使用,不过由于列表的元素可以是任何对象,因此列表中所保存的是对象的指针.这样为了保存一个简单的[1,2,3],需要有3 ...
- 使用 bufferedreader 的好处
简单的说,一次IO操作,读取一个字节也是读取,读取8k个字节也是读取,两者花费时间相差不多.而一次IO的来回操作却要耗费大量时间.好比是一辆大型汽车(设装100人),要去车站接人到公司,接一个人也是接 ...
- Why you should QC your reads AND your assembly?
鲤鱼基因组:http://www.ntv.cn/a/20140923/52953.shtml 关于鲤鱼基因组的测定,数据质量控制遭到质疑. Why you should QC your reads ...
- 开源Inno Setup官网下载、安装、打包教程(官网安装向导中文语言包)
安装Inno Setup篇 1.搜索Inno Setup 2.下载Inno Setup 3.选择下载最新 innosetup-5.5.9-unicode.exe 版本(innosetup-5.5.9. ...
- 【Python3之异常处理】
一.错误和异常 1.错误 代码运行前的语法或者逻辑错误 语法错误(这种错误,根本过不了python解释器的语法检测,必须在程序执行前就改正) def test: ^ SyntaxError: inva ...
- MySQL删除表方式差异
数据库删除语句 Drop/Delete/Truncate比较 Delete :删除数据表中的行(可以删除某一行,也可以在不删除数据表的情况下删除所有行). 删除某一行:Delete from 数据表名 ...
- app 选项卡代码
<div id="segmented" class="mui-segmented-control"> <a class="mui-c ...
- .NET C#到Java没那么难,MVC篇
最典型的JAVA MVC就是JSP + servlet + javabean的模式.比较好的MVC,老牌的有Struts.Webwork.新兴的MVC 框架有Spring MVC.Tapestry.J ...
- 对X86汇编的理解与入门
本文描述基本的32位X86汇编语言的一个子集,其中涉及汇编语言的最核心部分,包括寄存器结构,数据表示,基本的操作指令(包括数据传送指令.逻辑计算指令.算数运算指令),以及函数的调用规则.个人认为:在理 ...