千家信息网

DOM操作表格

发表于:2024-12-13 作者:千家信息网编辑
千家信息网最后更新 2024年12月13日,前面的话表格table元素是HTML中最复杂的结构之一。要想创建表格,一般都必须涉及表示表格行、单元格、表头等方面的标签。由于涉及的标签多,因而使用核心DOM方法创建和修改表格往往都免不了要编写大量的
千家信息网最后更新 2024年12月13日DOM操作表格

前面的话

  表格table元素是HTML中最复杂的结构之一。要想创建表格,一般都必须涉及表示表格行、单元格、表头等方面的标签。由于涉及的标签多,因而使用核心DOM方法创建和修改表格往往都免不了要编写大量的代码。本文将详细介绍DOM操作表格的属性和方法

需求

  要通过DOM实现下列格式的表格结构

Cell 1,1 Cell 2,1
Cell 1,2 Cell 2,2

DOMcore

  如果通过DOMcore方法,则方法如下

//创建表格var table = document.createElement("table");table.border = "1";table.width = "100%";//创建tbodyvar tbody = document.createElement("tbody");table.appendChild(tbody);//创建第一行var row1 = document.createElement("tr");tbody.appendChild(row1);var cell1_1 = document.createElement("td");cell1_1.appendChild(document.createTextNode("Cell 1,1"));row1.appendChild(cell1_1);var cell2_1 = document.createElement("td");cell2_1.appendChild(document.createTextNode("Cell 2,1"));row1.appendChild(cell2_1);//创建第二行var row2 = document.createElement("tr");tbody.appendChild(row2);var cell1_2 = document.createElement("td");cell1_2.appendChild(document.createTextNode("Cell 1,2"));row2.appendChild(cell1_2);var cell2_2 = document.createElement("td");cell2_2.appendChild(document.createTextNode("Cell 2,2"));row2.appendChild(cell2_2);//将表格添加到文档主体中document.body.appendChild(table);

属性和方法

  显然DOM代码很长,为了方便构建表格,HTML DOM为

、、元素添加了属性和方法。

【1】为

元素添加的属性和方法

caption:保存着对
元素的HTMLCollectiontFoot:保存着对元素的指针tHead:保存着对元素的指针createTHead():创建元素,将其放到表格中,返回引用createTFoot():创建元素,将其放到表格中,返回引用createCaption():创建元素deleteTFoot():删除元素deleteCaption():删除元素添加的属性和方法

rows:保存着
元素中行的HTMLCollectiondeleteRow(pos):删除指定位置的行insertRow(pos):向rows集合中的指定位置插入一行,返回对新插入行的引用

【3】为

元素添加的属性和方法

cells:保存着
元素中单元格的HTMLCollectiondeleteCell(pos):删除指定位置的单元格insertCell(pos):向cells集合中的指定位置插入一个单元格,返回对新插入单元格的引用

代码重写

//创建表格var table = document.createElement("table");table.border = "1";table.width = "100%";//创建tbodyvar tbody = document.createElement("tbody");table.appendChild(tbody);//创建第一行tbody.insertRow(0);tbody.rows[0].insertCell(0);tbody.rows[0].cells[0].appendChild(document.createTextNode("Cell 1,1"));tbody.rows[0].insertCell(1);tbody.rows[0].cells[1].appendChild(document.createTextNode("Cell 2,1"));//创建第二行tbody.insertRow(1);tbody.rows[1].insertCell(0);tbody.rows[1].cells[0].appendChild(document.createTextNode("Cell 1,2"));tbody.rows[1].insertCell(1);tbody.rows[1].cells[1].appendChild(document.createTextNode("Cell 2,2"));//将表格添加到文档主体中document.body.appendChild(table);

效果展示


0
元素的指针tBodies:是一个元素,将其放到表格中,返回引用deleteTHead():删除元素

【2】为