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 相关文章推荐
用Div仿showModalDialog模式菜单的效果的代码
Mar 05 Javascript
一个JQuery操作Table的代码分享
Mar 30 Javascript
Js注册协议倒计时的小例子
Jun 24 Javascript
让jQuery与其他JavaScript库并存避免冲突的方法
Dec 23 Javascript
js 右侧浮动层效果实现代码(跟随滚动)
Nov 22 Javascript
Angular.Js的自动化测试详解
Dec 09 Javascript
使用JavaScript实现链表的数据结构的代码
Aug 02 Javascript
js 两数组去除重复数值的实例
Dec 06 Javascript
浅谈vue异步数据影响页面渲染
Oct 29 Javascript
关于vue2强制刷新,解决页面不会重新渲染的问题
Oct 29 Javascript
vue实现输入框自动跳转功能
May 20 Javascript
JavaScript中的几种继承方法示例
Dec 06 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的ASCII码转换类
2013/07/05 PHP
一个简单的PHP验证码实现代码
2014/05/10 PHP
php中动态修改ini配置
2014/10/14 PHP
PHP 抽象方法与抽象类abstract关键字介绍及应用
2014/10/16 PHP
PHP SPL标准库之接口(Interface)详解
2015/05/11 PHP
PHP中如何防止外部恶意提交调用ajax接口
2016/04/11 PHP
JavaScript方法和技巧大全
2006/12/27 Javascript
在线编辑器中换行与内容自动提取
2009/04/24 Javascript
javascript数组的使用
2013/03/28 Javascript
jQuery的显示和隐藏方法与css隐藏的样式对比
2013/10/18 Javascript
jquery中插件实现自动添加用户的具体代码
2013/11/15 Javascript
用正则表达式替换图片地址img标签
2013/11/22 Javascript
js实现的标题栏新消息闪烁提示效果
2014/06/06 Javascript
jQuery实现鼠标经过提示信息的地图热点效果
2015/04/26 Javascript
基于jquery实现省市区三级联动效果
2015/12/25 Javascript
Angular懒加载机制刷新后无法回退的快速解决方法
2016/08/30 Javascript
JS 全屏和退出全屏详解及实例代码
2016/11/07 Javascript
JS求解三元一次方程组值的方法
2017/01/03 Javascript
jQuery仿写百度百科的目录树
2017/01/03 Javascript
JavaScript ES6中const、let与var的对比详解
2017/06/18 Javascript
JS 验证密码 不能为空,必须含有数字、字母、特殊字符,长度在8-12位
2017/06/21 Javascript
linux 下实现python多版本安装实践
2014/11/18 Python
PyQt5 对图片进行缩放的实例
2019/06/18 Python
jupyter notebook 实现matplotlib图动态刷新
2020/04/22 Python
基于python获取本地时间并转换时间戳和日期格式
2020/10/27 Python
python 日志模块logging的使用场景及示例
2021/01/04 Python
10张动图学会python循环与递归问题
2021/02/06 Python
中国跨境电子商务网站:NewFrog
2018/03/10 全球购物
高一历史教学反思
2014/01/13 职场文书
大学生2014全国两会学习心得体会
2014/03/10 职场文书
市场部经理岗位职责
2014/04/10 职场文书
厉行勤俭节约倡议书
2014/05/16 职场文书
计算机毕业生自荐信
2014/06/12 职场文书
临床专业自荐信
2014/06/22 职场文书
领导干部遵守党的政治纪律情况思想汇报
2014/09/14 职场文书
煤矿安全保证书
2015/02/27 职场文书