纯原生JS实现表格增删操作
102 浏览量
更新于2024-09-01
1
收藏 90KB PDF 举报
“纯原生js实现table表格的增删”
在网页开发中,有时需要使用JavaScript来处理DOM元素,特别是对于表格(table)的操作,如添加(增)和删除(删)行。本文将详细讲解如何仅使用JavaScript,不依赖jQuery等库,实现table表格的增删功能。
首先,一个基本的HTML结构是必不可少的。这里有一个包含三列的表格,带有创建(CREATE)、清除(CLEAR)和预留(GUESS)功能的按钮。CSS样式用于设置表格的边框和对齐方式。
```html
<!DOCTYPE HTML>
<html>
<head>
<title>table</title>
<meta charset='utf-8'/>
<style type="text/css">
table.base {
border-collapse: collapse;
text-align: center;
border: 1px solid black;
}
table, tr, td, th {
border: 1px solid black;
}
</style>
</head>
<body>
<div id="main-content">
<table id="main-table" class="base">
<thead>
<tr>
<th colspan="3">This is a table for operations by javascript</th>
</tr>
<tr>
<th><input type="button" value="CREATE" id="cp_btn" onclick="createTr()"/></th>
<th><input type="button" value="CLEAR" id="cl_btn" onclick="clearTrs()"/></th>
<th><input type="button" value="GUESS" id="cl_btn"/></th>
</tr>
</thead>
<tbody>
</tbody>
</table>
</div>
</body>
</html>
```
接下来,我们需要编写JavaScript函数来处理这些操作。首先创建一个名为`TableOperation`的“伪构造函数”(非严格意义上的构造函数,因为没有使用`new`关键字)。这个函数可以作为操作表格的基类,包含了添加行和清除所有行的功能。
```javascript
function TableOperation(tableId) {
this.table = document.getElementById(tableId);
this.trTemplate = this.table.rows[0];
}
TableOperation.prototype.createTr = function () {
var newRow = this.trTemplate.cloneNode(true);
this.table.tBodies[0].appendChild(newRow);
};
TableOperation.prototype.clearTrs = function () {
var tbody = this.table.tBodies[0];
while (tbody.firstChild) {
tbody.removeChild(tbody.firstChild);
}
};
```
在这个构造函数中,`this.table`指向了指定ID的表格,`this.trTemplate`则保存了表头行(thead中的第一行),用于后续的克隆操作。`createTr`方法通过调用`cloneNode(true)`来复制模板行,并将其添加到tbody中。`clearTrs`方法则通过迭代tbody的子节点并移除它们,实现了清除所有行的功能。
为了使用这个“伪构造函数”,需要创建一个新的实例并调用相应的方法:
```javascript
var tableOp = new TableOperation('main-table');
document.getElementById('cp_btn').addEventListener('click', function () {
tableOp.createTr();
});
document.getElementById('cl_btn').addEventListener('click', function () {
tableOp.clearTrs();
});
```
这里,我们为CREATE和CLEAR按钮分别绑定了`createTr`和`clearTrs`方法的调用。当用户点击按钮时,相应的操作就会被执行。
总结来说,实现纯原生JavaScript的表格增删功能,关键在于理解DOM操作,包括获取元素、添加和移除子节点。通过创建一个“伪构造函数”来封装这些操作,可以使得代码更加模块化和易于维护。在实际项目中,可能还需要处理更复杂的交互和兼容性问题,但以上内容提供了一个基础的实现框架。
526 浏览量
1556 浏览量
209 浏览量
967 浏览量
1052 浏览量
点击了解资源详情
770 浏览量
weixin_38702945
- 粉丝: 9
- 资源: 964
最新资源
- WebMiniProject
- ns-react-18next:[未维护]命名空间中的i18next本地化ReactSwift
- TemplateVue-bootstrap3-sass:模板
- 一组医疗图标 .xd .sketch .svg .fig素材下载
- Rad Studio XE 10.4 Patch 补丁合集 截止2020.7.29
- 基于HTML实现的仿智慧园区触屏版html5手机门户网站模板下载(css+html+js+图样).zip
- rhythmless.github.io:我的互联网片段
- BalanceCar调试版,计算机博弈大赛c语言源码,c语言
- qblueRed42.github.io
- torchdrift-redisai:RedisAI中的TorchDrift
- rnp-find:用于探索RNA与蛋白质相互作用的生物信息学工具
- ant-apache-bcel-1.9.3.zip
- C1220G1_NguyenDucHau
- flutter-localized-locales:Flutter插件,它提供语言环境代码到563个语言环境的名称映射
- html推箱子.zip
- 基于PCB的最新PCB及相关材料IEC标准信息 国际电工委员会.zip