源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

DOM基础教程之使用DOM控制表格

  • 时间:2020-10-06 17:46 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:DOM基础教程之使用DOM控制表格
表格的css控制就先不说了,首先分享下表格常用的DOM [img]http://files.jb51.net/file_images/article/201501/201501201543135.png[/img] 表格添加操作的方法常用的为insertRow()和insertCell()方法。 row是从零开始计算起的,例如:
[u]复制代码[/u] 代码如下:
var oTr = document.getElementById("member").insertRow(2)
是指将新行添加到第二行。
[u]复制代码[/u] 代码如下:
var aText = new Array(); aText[0] = document.createTextNode("fresheggs"); aText[1] = document.createTextNode("W610"); aText[2] = document.createTextNode("Nov 5th"); aText[3] = document.createTextNode("Scorpio"); aText[4] = document.createTextNode("1038818"); for(var i=0;i<aText.length;i++){ var oTd = oTr.insertCell(i); oTd.appendChild(aText[i]); }
变量oTr即为表格插入新行,再利用insertCell为这行插入新的数据,利用createTextNode创建新的文本节点,在appendChild给oTd,oTd即为新的单元格。   1.插入一行(动态添加表格)
[u]复制代码[/u] 代码如下:
<script type="text/javascript"> window.onload=function(){     var oTr = document.getElementById("member").insertRow(2);    //插入一行     var aText = new Array();     aText[0] = document.createTextNode("fresheggs");     aText[1] = document.createTextNode("W610");     aText[2] = document.createTextNode("Nov 5th");     aText[3] = document.createTextNode("Scorpio");     aText[4] = document.createTextNode("1038818");     for(var i=0;i<aText.length;i++){         var oTd = oTr.insertCell(i);         oTd.appendChild(aText[i]);     } } </script> <table class="datalist" summary="list of members in EE Studay" id="member">     <caption>Member List</caption>     <tr>         <th scope="col">Name</th>         <th scope="col">Class</th>         <th scope="col">Birthday</th>         <th scope="col">Constellation</th>         <th scope="col">Mobile</th>     </tr>     <tr>         <td>isaac</td>         <td>W13</td>         <td>Jun 24th</td>         <td>Cancer</td>         <td>1118159</td>     </tr>     <tr>         <td>girlwing</td>         <td>W210</td>         <td>Sep 16th</td>         <td>Virgo</td>         <td>1307994</td>     </tr>     <tr>         <td>tastestory</td>         <td>W15</td>         <td>Nov 29th</td>         <td>Sagittarius</td>         <td>1095245</td>     </tr> </table>
2.修改表格的内容 当表格建立后,可以直接使用HtmlDom对表格进行操作,相比document.getElementById(),document.getElementsByTagName()操作更为方便。 oTable.rows[i].cell[j] 以上通过rows、cells两个属性轻松访问到表格特定的内容第i行和第j列(都是从0开始计数),获得单元格对象后就可以使用innerHTML属性修改翔宇的内容了。 例如修改4行5列的内容为good 则可以使用以下代码
[u]复制代码[/u] 代码如下:
var oTable = document.getElementById("table1"); oTable.rows[4].cells[5].innerHTML = "good";
[b]3.删除表格内容[/b] 表格既然有添加、修改、就有删除功能。 表格中删除行使用deleteRow(i)方法,其中i为行号。 表格中删除列使用tr的deleteCell(j)方法。 如下代码表示删除表格的第二行及原来表格第三行的第二列
[u]复制代码[/u] 代码如下:
var oTable = document.getElementById("table1"); oTable.deleteRow[2]; oTable.rows[2].deleteCell[3];
如下代码表示删除表格的第二行及原来表格第三行的第二列 考虑到动态删除又不影响整体html框架,又或者表格内容很多的情况下,可以采用动态删除添加的办法
[u]复制代码[/u] 代码如下:
<script type="text/javascript"> window.onload=function(){     var oTr = document.getElementById("member").insertRow(2);    //插入一行     var aText = new Array();     aText[0] = document.createTextNode("fresheggs");     aText[1] = document.createTextNode("W610");     aText[2] = document.createTextNode("Nov 5th");     aText[3] = document.createTextNode("Scorpio");     aText[4] = document.createTextNode("1038818");     for(var i=0;i<aText.length;i++){         var oTd = oTr.insertCell(i);         oTd.appendChild(aText[i]);     } } </script> <table class="datalist" summary="list of members in EE Studay" id="member">     <caption>Member List</caption>     <tr>         <th scope="col">Name</th>         <th scope="col">Class</th>         <th scope="col">Birthday</th>         <th scope="col">Constellation</th>         <th scope="col">Mobile</th>     </tr>     <tr>         <td>isaac</td>         <td>W13</td>         <td>Jun 24th</td>         <td>Cancer</td>         <td>1118159</td>     </tr>     <tr>         <td>girlwing</td>         <td>W210</td>         <td>Sep 16th</td>         <td>Virgo</td>         <td>1307994</td>     </tr>     <tr>         <td>tastestory</td>         <td>W15</td>         <td>Nov 29th</td>         <td>Sagittarius</td>         <td>1095245</td>     </tr> </table>
删除列
[u]复制代码[/u] 代码如下:
function deleteColumn(oTable, iNum) {                 //自定义删除列函数,即每行删除相应单元格                 for (var i = 0; i < oTable.rows.length; i++)                     oTable.rows[i].deleteCell(iNum);             }             window.onload = function() {                 var oTable = document.getElementById("table1");                 deleteColumn(oTable, 2);             }
对于删除表格列而言,DOM中没有直接可调用的方法,需要自己来写deleteColumn()方法,该方法接受两个参数,一个参数是表格对象,另外一个参数则是希望删除的列号。编写方法很简单,利用deleteCell()方法,每一行都执行相应的删除单元格的方法。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部