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 相关文章推荐
javascript 鼠标滚轮事件
Apr 09 Javascript
Jquery 获取对象的几种方式介绍
Jan 17 Javascript
jQuery设置与获取HTML,文本和值的简单实例
Feb 26 Javascript
jQuery实现获取table表格第一列值的方法
Mar 01 Javascript
Bootstrap组件系列之福利篇几款好用的组件(推荐)
Jun 23 Javascript
js 获取当前web应用的上下文路径实现方法
Aug 19 Javascript
Node.js如何响应Ajax的POST请求并且保存为JSON文件详解
Mar 10 Javascript
基于vue 添加axios组件,解决post传参数为null的问题
Mar 05 Javascript
JavaScript函数式编程(Functional Programming)组合函数(Composition)用法分析
May 22 Javascript
layui button 按钮弹出提示窗口,确定才进行的方法
Sep 06 Javascript
OpenLayers3实现地图显示功能
Sep 25 Javascript
详解如何解决使用JSON.stringify时遇到的循环引用问题
Mar 23 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
PHP5中实现多态的两种方法实例分享
2014/04/21 PHP
php提交post数组参数实例分析
2015/12/17 PHP
Nginx下ThinkPHP5的配置方法详解
2017/08/01 PHP
PHP文件操作简单介绍及函数汇总
2020/12/11 PHP
javascript 写类方式之二
2009/07/05 Javascript
javascript object array方法使用详解
2012/12/03 Javascript
js/html光标定位的实现代码
2013/09/23 Javascript
node.js使用npm 安装插件时提示install Error: ENOENT报错的解决方法
2014/11/20 Javascript
JavaScript中捕获与冒泡详解及实例
2017/02/03 Javascript
微信小程序 仿美团分类菜单 swiper分类菜单
2017/04/12 Javascript
对类Vue的MVVM前端库的实现代码
2018/09/07 Javascript
Vue 重置组件到初始状态的方法示例
2018/10/10 Javascript
搭建一个nodejs脚手架的方法步骤
2019/06/28 NodeJs
nodeJs的安装与npm全局环境变量的配置详解
2020/01/06 NodeJs
vue-amap根据地址回显地图并mark的操作
2020/11/03 Javascript
Python 创建子进程模块subprocess详解
2015/04/08 Python
Python正则表达式教程之一:基础篇
2017/03/02 Python
利用Python实现网络测试的脚本分享
2017/05/26 Python
Python数据结构之顺序表的实现代码示例
2017/11/15 Python
使用Django开发简单接口实现文章增删改查
2019/05/09 Python
win10子系统python开发环境准备及kenlm和nltk的使用教程
2019/10/14 Python
python二元表达式用法
2019/12/04 Python
python 消费 kafka 数据教程
2019/12/21 Python
python正则过滤字母、中文、数字及特殊字符方法详解
2020/02/11 Python
keras实现多种分类网络的方式
2020/06/11 Python
整理HTML5移动端开发的常用触摸事件
2016/04/15 HTML / CSS
国际化的太阳镜及太阳镜配件零售商:Sunglass Hut
2016/07/26 全球购物
华为慧通笔试题
2016/04/22 面试题
园林设计师自荐信
2013/11/18 职场文书
园林毕业生自我鉴定范文
2013/12/29 职场文书
最热门的自我评价
2013/12/30 职场文书
老公保证书范文
2014/04/29 职场文书
走近毛泽东观后感
2015/06/04 职场文书
2016年党员学习廉政准则心得体会
2016/01/20 职场文书
2016年秋季趣味运动会开幕词
2016/03/04 职场文书
Python+Appium实现自动抢微信红包
2021/05/21 Python