JavaScript 学习笔记(十三)Dom创建表格


Posted in Javascript onJanuary 21, 2010

Dom基础—创建表格
利用js来动态创建表格有两种格式,appendChild()和insertRow、insertCell()。但第一种有可能在IE上有问题,所以推荐使用第二种。
1、insertRow(index):index从0开始
这个函数将新行添加到index的那一行前,比如insertRow(0),是将新行添加到第一行之前。默认的insertRow()函数相当于 insertRow(-1),将新行添加到表的最后。一般我们在使用的时候都是:
objTable.insertRow (objTable.rows.length)就是为表格objTable在最后新增一行。
insertCell()和insertRow的用法相同。
2、deleteRow(index):index从0开始
删除指定位置的行,要传入的参数:Index是行在表格中的位置,可以下面的方法取得然后去删除:
var row = document.getElementById("行的Id");
var index = row.rowIndex; //有这个属性
objTable.deleteRow(index);
在使用过程中,删除表格的行的时候,如果删除了某一行,那么表格行数是马上就变化的,rows.length总是在变小,所以如果你要删除表格的所有行:

function removeAllRow() { 
var objTable = document.getElementById("myTable"); 
var length = objTable.rows.length; 
for (var i = 1; i < length; i++) { 
objTable.deleteRow(i); 
} 
}

3、setAttribute()方法,动态设置单元格与行的属性
格式如下:setAttribute(属性,属性值)
var objMyTable = document.getElementById("myTable");
objMyTable.setAttribute("border", 1); //为表格设置边框为1
在使用的时候遇到一个设置样式的问题,不能用
setAttribute("class","inputbox1");而应该使用
setAttribute("className","inputbox1"),
4、创建表格
了解了行<tr>与单元格<td>的增删那就可以创建表格了。
第一步:你需要有一个你去动态变化的表格,这里讲的是已经存在页面的表格,我们设置一个id:myTable

var objMyTable = document.getElementById("myTable");
第二步:创建行与列的对象

var index = objMyTable.rows.length; 
var nextRow = objMyTable.insertRow(index); //在最后的行 
//var nextRow = objMyTable.insertRow(0); //在最前的行

下面是示例代码
<script type="text/javascript"> 
var Count = false; //控制交替换行 
var NO = 1; //行号 
function addRow() { 
Count = !Count; 
//添加一行 
var newTr = table.insertRow(table.rows.length); //在最后新增一行 
//var newTr = table.insertRow(0); //在最前面新增一行 
//添加两列 
var newTd0 = newTr.insertCell(); 
var newTd1 = newTr.insertCell(); 
var newTd2 = newTr.insertCell(); 
//设置列内容和属性 
if (Count) { 
newTr.style.background = "#FFE1FF"; 
} 
else { 
newTr.style.background = "#FFEFD5"; 
} 
NO++; 
newTd0.innerHTML = '<input type=checkbox id="box' + NO + '" />'; 
newTd1.innerText = "第" + NO + "行"; 
newTd2.innerHTML = '<input type="text" id="Text' + NO + '" />'; 
} 
</script> 
<body> 
<form id="form1" runat="server"> 
<input type="button" value="插入行" onclick="addRow()" /> 
<table width="399" border="0" cellspacing="1" id="table" style="font-size: 14px;"> 
<tr bgcolor="#FFEFD5"> 
<td width="6%"> 
<input type="checkbox" id="box1" /> 
</td> 
<td> 
第1行 
</td> 
<td> 
<input id="Text1" type="text" /> 
</td> 
</tr> 
</table> 
</form> 
</body>
Javascript 相关文章推荐
jQuery 处理网页内容的实现代码
Feb 15 Javascript
JavaScript实现网站访问次数统计代码
Aug 12 Javascript
Ajax的概述与实现过程
Nov 18 Javascript
Vue生命周期示例详解
Apr 12 Javascript
详解最新vue-cli 2.9.1的webpack存在问题
Dec 16 Javascript
vue组件实现弹出框点击显示隐藏效果
Oct 26 Javascript
Vue CLI3 开启gzip压缩文件的方式
Sep 30 Javascript
JS中的算法与数据结构之栈(Stack)实例详解
Aug 20 Javascript
使用p5.js实现动态GIF图片临摹重现
Oct 23 Javascript
详解小程序横屏方案对比
Jun 28 Javascript
js实现批量删除功能
Aug 27 Javascript
在Angular项目使用socket.io实现通信的方法
Jan 05 Javascript
JavaScript 学习笔记(十二) dom
Jan 21 #Javascript
javascript parseInt与Number函数的区别
Jan 21 #Javascript
js parsefloat parseint 转换函数
Jan 21 #Javascript
jquery 防止表单重复提交代码
Jan 21 #Javascript
javascript 哈希表(hashtable)的简单实现
Jan 20 #Javascript
JS 对象介绍
Jan 20 #Javascript
JavaScript 学习笔记(十一)
Jan 19 #Javascript
You might like
PHP Document 代码注释规范
2009/04/13 PHP
PHP防止刷新重复提交页面的示例代码
2015/11/11 PHP
php socket通信(tcp/udp)实例分析
2016/02/14 PHP
PHP基于mcript扩展实现对称加密功能示例
2019/02/21 PHP
小议javascript 设计模式 推荐
2009/10/28 Javascript
不同浏览器对回车提交表单的处理办法
2010/02/13 Javascript
javascript document.compatMode兼容性
2010/02/23 Javascript
用JS实现一个TreeMenu效果分享
2011/08/28 Javascript
JsRender for index循环索引用法详解
2014/10/31 Javascript
JavaScript实现关键字高亮功能
2014/11/12 Javascript
jQuery蓝色风格滑动导航栏代码分享
2015/08/19 Javascript
完美的js div拖拽实例代码
2016/09/24 Javascript
BootStrap实现带关闭按钮功能
2017/02/15 Javascript
jquery拼接ajax 的json和字符串拼接的方法
2017/03/11 Javascript
vue使用stompjs实现mqtt消息推送通知
2017/06/22 Javascript
vue中appear的用法
2017/08/17 Javascript
关于Vue实现组件信息的缓存问题
2017/08/23 Javascript
Node.js创建Web、TCP服务器
2017/12/05 Javascript
JS中创建自定义类型的常用模式总结【工厂模式,构造函数模式,原型模式,动态原型模式等】
2019/01/19 Javascript
详解小程序开发经验:多页面数据同步
2019/05/18 Javascript
微信小程序手动添加收货地址省市区联动
2020/05/18 Javascript
[48:31]DOTA2-DPC中国联赛 正赛 Dynasty vs XG BO3 第一场 2月2日
2021/03/11 DOTA
python XlsxWriter模块创建aexcel表格的实例讲解
2018/05/03 Python
py-charm延长试用期限实例
2019/12/22 Python
使用CSS3来制作消息提醒框
2015/07/12 HTML / CSS
IE10 Error.stack 让脚本调试更加方便快捷
2013/04/22 HTML / CSS
Brasty波兰:香水、化妆品、手表网上商店
2019/04/15 全球购物
黑猩猩商店:The Chimp Store
2020/02/12 全球购物
俄罗斯便宜的在线服装商店:GroupPrice
2020/04/10 全球购物
学校联谊活动方案
2014/02/15 职场文书
信息总监管理职责范本
2014/03/08 职场文书
自习课吵闹检讨书范文
2014/09/26 职场文书
2017寒假社会实践心得体会范文
2016/01/14 职场文书
Ajax是什么?Ajax高级用法之Axios技术
2021/04/21 Javascript
基于angular实现树形二级表格
2021/10/16 Javascript
oracle设置密码复杂度及设置超时退出的功能
2022/06/28 Oracle