javascript 动态添加表格行

源自:楚一笑 (个人网站) 标签:web开发

动态添加表格行 

文/Ray

 表格部分代码如下:

<table id="testTbl" border=1>

<tr id="tr1">

<td width=6%><input type=checkbox id="box1"></td>

<td id="b">第一行</td>

</tr>

<tr id="tr2">

<td width=6%><input type=checkbox id="box2"></td>

<td id="b">第二行</td>

</tr>

<tr bgcolor=#0000FF>

<td width=6%><input type=checkbox id="box3"></td>

<td>第三行</td>

</tr>

</table>

动态添加表行的javascript函数如下:

function addRow(){

//添加一行

var newTr = testTbl.insertRow();

//添加两列

var newTd0 = newTr.insertCell();

var newTd1 = newTr.insertCell();

//设置列内容和属性

newTd0.innerHTML = '<input type=checkbox id="box4">';

newTd2.innerText= '新加行';

}

就这么简单,做点详细的说明:

1inserRow()insertCell()函数

insertRow()函数可以带参数,形式如下:

insertRow(index)

这个函数将新行添加到index的那一行前,比如insertRow(0),是将新行添加到第一行之前。默认的insertRow()函数相当于insertRow(-1),将新行添加到表的最后。

insertCell()insertRow的用法相同。

2、动态设置属性和事件

上面行数中的innerHTML和innerText都是列的属性。

这个inner,就是“inner”到<tb></tb>之间,innerText是添加到<tb></tb>之间的文本,innerHTML是添加到<tb></tb>之间的HTML代码(这个so简单,这个解释挺多余的)

设置其他属性也是用同样的方式,比如,设置行背景色

newTr.bgColor = 'red';

 

设置事件也一样,需要简单说明一点。

比如,我要让点击新加行的时候执行一个自己定义的函数 newClick,newClick行数如下:

function newClick(){

alert("这是新添加的行");

onclick事件设置这个函数的代码如下:

newTr.onclick = newClick;

这里需要主义的是,=后面的部分必须是函数名,而且不能带引号,

newTr.onclick = newClick();

newTr.onclick = 'newClick';

newTr.onclick = "newClick";

上面的写法都是错误的。

为什么,其实知道为什么没有什么意思,知道怎么用就OK了,如果不想知道,可以跳过下面这一段。

 

实际上这个=后面的newClick是指向自己定义的newClick函数的指针,javascript里面函数名就是指向函数的指针,加了引号括号什么的浏览器就找不到那个函数了。

下面的写法,也是正确的

newTr.onclick = function newClick(){

alert("这是新添加的行");

这个使用函数名实际上是一样的

 

设置其他的事件用法相同。

 

您认为本文应该得  1 2 3 4 5        共有3人参与打分打印|收藏|讨论|投诉

 

作者其他文章: 更多
  • 在ModalDialog中操作父窗口对象
  • java中的时间操作 一
  • oracle-快速删除重复的记录
  • oracle使用了索引但是查询性能没有改善(oracle的索引陷阱)
相关文章:
     
评论
wangwen2020  2006-7-3 16:21:59 
newTd2.innerText= '新加行'; 写错了,应改为newTd1.innerText= '新加行';就没问题了.
leeight  2006-6-30 13:01:26 
CSDN这是干什么呢? FF下面发表评论的时候, 提交的时候escape就escape吧, 为什么还显示出来, 看起来多难看啊
leeight  2006-6-30 13:00:34 
很不好, FF下面就不行。 insertRow(), insertCell()最好带上参数才可以再FF下面用的。而再IE下面就不需要了。
sportdog  2006-6-21 16:15:43 
我觉得不用那么复杂,用innerHTML就可以了。也就是说你只要把你的表格看成一个字符串在innerHTML就可以了!
RUKYO  2006-6-21 13:56:40 
呵呵~~已经找到了。
 

你可能感兴趣的:(javascript 动态添加表格行)