说明:appendChild()
我测试的结果:
1 appendChild() 表格中所有行循环上移一行后, 用新的(行)替换了 表格的末行 ;相当于替换了表格的第一行,并循环上移一行
2 不改变 表格的总 行数
insertRow()
1 insertRow() 在表格中插入一行,表格总行书增一
2 insertRow(index) index=0 , 在表头增加, index=-1, 在表尾增加。
deleteRow()
1 deleteRow(0) 删除表头第一行, 第二行变为第一行; 因此删除表头前n行,可以循环n次调用deleteRow(0)
Example: Sort table & Merge same Column1。 Break Table: 遍历表格,如果排序列 的某TD包含多个值, 需要拆分为多行(使用insertRow(-1); index=-1是因为便利过程使用原有表格的行数进行遍历,若在表头插入行则遍历失效)2。 Sort Table:
a,将表格中的代排序行保存到数组ArrayOrig中,
b: 排序数组ArrayOrig
c:遍历数组ArrayOrig,合并相同列,生成ArrayDest(注意合并过程中需要保证状态,属性符合需求)
d: 遍历ArrayDest,使用appendChild() 添加到表格中。
3。 Delete Table: 因为appendChild()不会改变表格行数,因此适用 count=ArrayOrig.length - ArrayDest.length 循环调用deleteRow(0)删除表前count行以下为 网上的 一些资料:http://zxjava.javaeye.com/blog/1939261、inserRow()和insertCell()函数
insertRow(index):index从0开始
这个函数将新行添加到index的那一行前,比如insertRow(0),是将新行添加到第一行之前。默认的insertRow()函数相当于 insertRow(-1),将新行添加到表的最后。一般我们在使用的时候都是:objTable.insertRow(objTable.rows.length).就是为表格objTable在最后新增一行。
insertCell()和insertRow的用法相同,这里就不再说了。
2、deleteRow()和deleteCell()方法
deleteRow(index):index从0开始
删除指定位置的行和单元格。要传入的参数:Index是行在表格中的位置,可以下面的方法取得然后去删除:
var row=document.getElementById("Row_Id");
var index=row.rowIndex;
objTable.deleteRow(index);
删除表格的行的时候,如果你删除了某一行,那么表格行数是马上就变化的,所以如果你要删除表格的所有行,下面的代码是错误的:
function clearRow(){
objTable= document.getElementById("myTable");
for( var i=1; i
{
tblObj.deleteRow(i);
}
}
这段代码要删除原来的表格的表体,有两个问题。首先不能是deleteRow(i),应该是deleteRow(1)。因为在删除表格行的时候,表格的行数在变化,这就是问题的关键,rows.length总是在变小,删除的行数总是会比预想的要少一半,所以正确的删除表格的行的代码应该这样:
function clearRow(){
objTable= document.getElementById("myTable");
var length= objTable.rows.length ;
for( var i=1; i{
objTable.deleteRow(i);
}
}
3、动态设置单元格与行的属性
A、采用setAttribute()方法,格式如下:setAttribute(属性,属性值)
说明:这个方法几乎所有的DOM对象都可以使用,第一个参数是属性的名称,比如说:border,第二个就是你要为border设置的值了,比如:1
var objMyTable = document.getElementById("myTable");
objMyTable.setAttribute("border",1);//为表格设置边框为1
其他的比如你要为一个TD设置高度,同样先取得这个TD对象,然后使用setAttribute()方法
var objCell = document.getElementById("myCell");
objCell.setAttribute("height",24);//为单元格设置高度为24
在使用的时候遇到一个设置样式的问题,不能用setAttribute("class","inputbox2");而应该使用 setAttribute("className","inputbox2"),呵呵,其他我估计也有同样的问题,有些属性和我们在DW里面的不一致,呵呵,大家自己摸索吧。
B、直接赋值
var objMyTable = document.getElementById("myTable");
objMyTable.border=1;//为表格设置边框为1
4、创建表格
了解了行与单元格的增删那就可以创建表格了。
第一步:你需要有一个你去动态变化的表格,我这里讲的是已经存在页面的表格,我们要设置一个id:myTable
var objMyTable = document.getElementById("myTable");
第二步:创建行与列的对象
var index = objMyTable.rows.length-1; var nextRow = objMyTable.insertRow(index);//要新增的行,我这里是从倒数第二行开始新增的
var newCellCartonNo = nextRow.insertCell(); var cartonNoName = "IptCartonNo"; newCellCartonNo.innerHTML = " "; newCellCartonNo.setAttribute("className","tablerdd");
这样就搞定了,可以简单的创建一个行和列了。具体的代码我贴在下面。只是很简单的例子,不过方法就大概是上面的了,呵呵,慢慢摸索吧~
蓝光-BlueShine
5、appendChild()方法
我就直接贴代码了,大家去研究,时间紧,哈哈,见谅~
My Test Page
My Test Page
阅读(1664) | 评论(0) | 转发(0) |
|