
核心代码:
<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向数据库提交就行了,,,原理基本这样,,,自己想一下哈,有利于自己发展您好,编写的js代码:<喎�"http://www.2cto.com/kf/ware/vc/" target="_blank" class="keylink">vcD4KPHByZSBjbGFzcz0="brush:java">$(document).ready(function () { $('.view').click(function(){ //添加遮罩层 var maskHeight=$(document).height()var maskWidth=$(document).width()$('
').appendTo($('body'))$('div.mask').css({ 'opacity':0.4, 'background':'#000', 'position':'absolute', 'left':0, 'top':0, 'height':maskHeight, 'width':maskWidth, 'z-index':2 })//获取表格中的数据 var arr=[]$(this).parent().siblings().each(function(){ arr.push($(this).text())})$('.popDiv').show().children().each(function(i){ $(this).children('span').text(arr[i])}) //关闭 $('.close').click(function(){ $(this).parent().hide()$('.mask').remove()//注意这里不能用hide,因为会不断生成mask })})//删除 $('.del').click(function(){ $(this).parents('tr').remove()})})
点击关闭遮罩消失,点击删除即可删除。修改这里就不放代码了,有兴趣的可以自己动手写写。相信用js写过显示和遮罩这个功能的用Jquery就体会到了它的强大。
在写移除遮罩的时候想当然的也跟点击关闭的时候用.hide但是在火狐调试器下面观察到了每当点击一次查看然后关闭,遮罩层虽然是消失了但是DOM树下每次都会多产生一个div,所以得用移除。不是功能正常了就万事无忧了,最重要的是怎样优化使得代码的效率更高。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)