Dom的cloneNode方法

该方法将复制并返回调用它的节点的副本。如果传递给它的参数是 true,它还将递归复制当前节点的所有子孙节点。否则,它只复制当前节点。
返回的节点不属于文档树,它的 parentNode 属性为 null。
当复制的是 Element 节点时,它的所有属性都将被复制。但要注意,当前节点上注册的事件监听器函数不会被复制。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>控件cloneNode()方法的使用</title>
<script language="javascript">
 i=1;
 function AddRow()
 {
   var tableObject=new Object();
   
   var isneed=true;
   
   tableObject=document.getElementById("CloneNodeShow");
   //判断是否有必要添加新的输入行
   for(var j=0;j<tableObject.getElementsByTagName("input").length;j++)
   {
    var inputs = tableObject.getElementsByTagName("input")[j]; 
    if(inputs.type=="text" && inputs.value=="")
    {
     isneed=false;
    }
   }
   if(isneed)
   {
    //添加一行   
    var newTR=tableObject.insertRow(tableObject.rows.length);
    var td0=newTR.insertCell(newTR.cells.length);
    var td1=newTR.insertCell(newTR.cells.length);
    var td2=newTR.insertCell(newTR.cells.length);
    var td3=newTR.insertCell(newTR.cells.length);
    
    td0.innerHTML=(++i)+'.';
    td1.innerHTML='<input type="text" name="username"/>';
    //true表示深度克隆
    var newSelect=document.getElementById("sexType").cloneNode(true);
    newSelect.id="sexType"+i;
    td2.appendChild(newSelect);
    td3.innerHTML='<input type="text" name="age" onchange="AddRow()"/>';   
   }
 }
 
 function addT(){
	var newT=document.getElementById('CloneNodeShow').cloneNode(true);
	document.body.appendChild(newT);
 }
</script>
</head>
<body>
<input type="button" value="AddTable" onclick="addT();"/>
<form>
 <table id="CloneNodeShow" border="2" bordercolor="#000000">
  <tr><th></th><th>姓名</th><th>性别</th><th>年龄</th></tr>
  <tr id="signTR"  >
   <td>1.</td>
   <td><input type="text" name="username"/></td>
   <td>
    <select name="sexType" id="sexType">
     <option value="%">请选择性别</option>
     <option value="0">男</option>
     <option value="1">女</option>
    </select>
   </td>
   <td><input type="text" name="age" onchange="AddRow()"/></td>
  </tr>
 </table>
</form>
</body>
</html>

点击按钮可以深复制了整个表格,但是表格中的age文本框的onchange事件并没有被clone。

你可能感兴趣的:(浏览器,XHTML,IE,J#,firefox)