核心代码:
<script type="text/javascript">
function removeTable(){
var objDiv = document.getElementById("divid")
var vtables = objDiv.childNodes//
if (vtables.length >0)
objDiv.removeChild(vtables[vtables.length - 1])
}
</script>
<input type="button" value="删除表格" onclick="javascript:removeTable()" />
===============================================
<!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/htmlcharset=gb2312" />
<title>Untitled Document</title>
<script type="text/javascript">
function createTable(){
var objDiv = document.getElementById("divid")
var vtable=document.createElement("table")
// vtable.id="idTB"
vtable.cellPadding="0",
vtable.cellSpacing="0"
vtable.border="1"
vtable.color="#000000"
vtable.borderColorDark="#000000"
vtable.borderColorLight="#FFFFFF"
for(i=0i<1i++){
var vtr=vtable.insertRow(i)//insertRow插入行
for(k=0k<5k++){
vtd=vtr.insertCell(k)//insertCell插入列
vtd.innerHTML="<input type=text style='border:0px solid'>"// InnerHtml 是用来获取或设置位于指定的服务器控件的开始标记和结束标记之间的内容。
}
}
objDiv.appendChild(vtable)//appendChild方法可向节点的子节点列表的末尾添加新的子节点。此方法可返回这个新的子节点。
}
function mouseDown(){
if(event.button==2) {
if(event.srcElement.tagName="INPUT"){ //srcElement 对于生成事件的 Window 对象、Document 对象或 Element 对象的引用。
//tagName 属性返回被选元素的标签名。
window.confirm(event.srcElement.value)
}
}
}
document.onmousedown=mouseDown//onmousedown 事件会在鼠标按键被按下时发生
document.captureEvents(Event.MOUSEDOWN)
/* function RemoveRow()
{
oTR=idTB.rows(idTB.rows.length-1)
oTR.removeNode(true)
} */
function removeTable(){
var objDiv = document.getElementById("divid")
var vtables = objDiv.childNodes//
if (vtables.length >0)
objDiv.removeChild(vtables[vtables.length - 1])
}
</script>
</head>
<input type="button" value="创建表格" onclick="javascript:createTable()" />
<input type="button" value="删除表格" onclick="javascript:removeTable()" />
<!-- <input type="button" onclick="RemoveRow()" value="减一行">-->
<div id="divid"></div>
<body>
</body>
</html>
几点意见:
1.象1楼说的,<div id="divid"></div>应该放在body里。
2.<script标签的属性不对。
3.直接引用id当作对象本身只在IE下有效,应该用document.getElementById("")来获取对象。
其他你看我给你的页面吧,已经在DW里优化过了。
这个嘛,太简单。。。。注意的是比如第一列 ,tr中一个span,一个input,当span显示的时候,input隐藏,input显示时span隐藏就好了,,,,原理基本这样最后保存或删除,修改的时候用ajax向数据库提交就行了,,,原理基本这样,,,自己想一下哈,有利于自己发展<!DOCTYPE html><html>
<head>
<title>MyHtml.html</title>
<style type="text/css">
table{
border-collapse: collapse
}
td{
border:1px solid red
}
</style>
<script type="text/javascript">
function addtd(obj){
var td = document.createElement("td")
var input = document.createElement("input")
var inputBtn = document.createElement("input")
input.setAttribute("type", "text")
inputBtn.setAttribute("type", "button")
inputBtn.setAttribute("value", "删除")
inputBtn.setAttribute("onclick", "deltd(this)")
obj.parentNode.insertBefore(td, obj)
td.appendChild(input)
td.appendChild(inputBtn)
}
function deltd(a){
a.parentNode.parentNode.removeChild(a.parentNode)
}
function deltr(obj){
obj.parentNode.parentNode.removeChild(obj.parentNode)
}
function addtr(){
var tab = document.getElementById("tab")
var span = document.createElement("span")
var tr = document.createElement("tr")
var input = document.createElement("input")
var inputDel = document.createElement("input")
inputDel.setAttribute("type", "button")
inputDel.setAttribute("value", "删除此行")
inputDel.setAttribute("onclick", "deltr(this)")
input.setAttribute("type", "button")
input.setAttribute("value", "增加单元格")
input.setAttribute("onclick", "addtd(this)")
span.appendChild(input)
span.appendChild(inputDel)
tr.appendChild(span)
tab.appendChild(tr)
}
</script>
</head>
<body>
<form action="">
<input type="button" onclick="addtr()" id="add" value="增加行"/>
<table id="tab">
</table>
</form>
</body>
</html>
有问题追问
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)