灵魂-放水

为学日益,为道日损。

BlogJava 首页 新随笔 联系 聚合 管理
  296 Posts :: 10 Stories :: 274 Comments :: 0 Trackbacks

收集:

<HTML>
<SCRIPT LANGUAGE="javascript">

var count = 0; //count the number of rows

function tb_addnew() //添加行
{
var ls_t=document.all("mytable")
maxcell=ls_t.rows(0).cells.length; //取得表宽
mynewrow = ls_t.insertRow(); //插入新行
    for(i=0;i<maxcell;i++)
    {
    mynewcell=mynewrow.insertCell(); //在新行中顺序插入表格单元
    mynewcell.innerHTML = "<input name='row"+count+"' value = 'row"+count+"'>"//在表格单元中添加文本输入框
 //值存在一个隐藏表单域中,以便提交时使用,使用数组方法接收值
    }
 count++;
}

function tb_delete() //删除行
{
var ls_t=document.all("mytable");

if(count >  0)
 {
 ls_t.deleteRow() ; //删除最末一行
 count--;
 }
}

</SCRIPT>
<BODY>
<TABLE id=mytable border=1>
 <TR><TH>第一列</TH><TH>第二列</TH><TH>第三列</TH><TH>第四列</TH></TR>
</TABLE>
 <input type=button value="新增" onclick="tb_addnew()">
 <input type=button value="删除" onclick="tb_delete()" >
</BODY>
</HTML>
 
1,动态删除Table 里面内容技巧,不需要写太多代码,一行:
tb.removeNode(true)

2,动态增加行,除了CreateElement方法,还可以这样比较短小:

<table id=tb1></table>
<SCRIPT>
function addTable(){
  var row1 = tb1.insertRow();
  var cell1=row1.insertCell();
  var cell2=row1.insertCell();
  cell1.innerText="灰豆宝宝";
  cell2.innerText="超级大笨狼"
}
</SCRIPT>
<INPUT TYPE = "button" VALUE = "AddTable" onclick = "addTable()">

3,在DIV中动态增加Table

<SCRIPT>
function addTable(){
  var tb1 = document.createElement("table");
  tb1.border="1px";
  var row1 = tb1.insertRow();
  var cell1=row1.insertCell();
  var cell2=row1.insertCell();
  mydiv.appendChild(tb1);
  cell1.innerText="wanghr100";
  cell2.innerText="panyuguang962"
}
</SCRIPT>
<BODY>
<div id=mydiv style="width:400;height:300;"></div>
<INPUT TYPE = "button" VALUE = "AddTable" onclick = "addTable()">

4,在DIV中删除Table,简单只要Div.innerHTML=""就可以。

以上是部分实用相对短小的代码,当然有其他各种办法实现,不过一般都比上面的长,比如组合使用DIV对象的insertAdjacentHTML 方法等,在不同需要下使用不同方法,前提是研究好浏览器模型 的各种对象的方法属性。尤其是熟悉CSS+HTML就会做的很酷。就JS语言本身来说要求不高。

以下是以Document对象为例,相关方法有:

Method Description
attachEvent
createAttribute  
createComment  
createDocumentFragment
createElement
createEventObject
createStyleSheet
createTextNode
detachEvent
getElementById  
getElementsByName
getElementsByTagName
mergeAttributes
recalc
write  
writeln
以DIV对象为例相关方法有:
addBehavior
appendChild
applyElement
attachEvent
clearAttributes
cloneNode
contains
detachEvent
getAdjacentText  
getAttribute  
getAttributeNode
getElementsByTagName
hasChildNodes
insertAdjacentElement
insertAdjacentHTML
insertAdjacentText
insertBefore
mergeAttributes
normalize
removeAttribute
removeAttributeNode  
removeBehavior
removeChild
removeExpression
removeNode
replaceAdjacentText
replaceChild
replaceNode
setActive
setAttribute
setAttributeNode
setExpression  

其他,比如下拉列表对象,和拖拽操作等我有时间也整理比较一下,实现相同功能,相对比较短的精彩代码是值得收藏的。


1. removeNode(true) 非IE浏览器不支持的,应该用 obj.parentNode.removeChild(obj);
2. insertRow(x) insertCell(y) 这个参数是IE里是可以缺省,但是在非IE浏览器里不可缺省


<SCRIPT>
function addTable(){
  var tb1 = document.createElement("TABLE");
  tb1.border="1px";
  var row1 = tb1.insertRow(0);
  var cell1=row1.insertCell(0);
  var cell2=row1.insertCell(1);
  document.getElementById("mydiv").appendChild(tb1);
  cell1.innerHTML="wanghr100";
  cell2.innerHTML="panyuguang962";
  row1.insertCell(2).innerHTML="要注意:给的例子要考虑全面";
}
</SCRIPT>
<BODY>
<div id="mydiv" style="width:400;height:300;"></div>
<INPUT TYPE = "button" VALUE = "AddTable" onclick = "addTable()">

posted on 2006-12-17 11:32 放水老倌 阅读(609) 评论(0)  编辑  收藏 所属分类: JavaScript

只有注册用户登录后才能发表评论。


网站导航:
博客园   IT新闻   Chat2DB   C++博客   博问