0

0

使用纯 JavaScript 实现动态表格的增删改功能教程

心靈之曲

心靈之曲

发布时间:2025-09-24 10:42:01

|

868人浏览过

|

来源于php中文网

原创

使用纯 JavaScript 实现动态表格的增删改功能教程

本教程详细介绍了如何使用纯 JavaScript 在网页中实现动态表格的添加、编辑和删除(CRUD)功能。我们将通过一个实际示例,逐步讲解如何构建交互式表格,特别是修正了编辑功能中常见的将单元格内容转换为可编辑输入框的关键步骤,并提供了完整的代码实现及最佳实践建议。

引言

在现代 web 应用开发中,动态表格操作是常见的需求,例如管理用户列表、商品库存等。本教程将指导您如何仅使用 javascript 来实现对表格行的添加、编辑和删除功能,无需依赖任何后端语言(如 php)。我们将从一个基本的 html 结构开始,逐步完善各项功能,并特别关注编辑功能的实现细节,解决在将静态文本转换为可编辑输入框时可能遇到的问题。

1. 初始 HTML 结构概述

为了演示动态表格操作,我们首先需要一个基本的 HTML 表格结构。本例中,我们将使用 JavaScript 动态生成表格,但实际项目中,表格通常会预先定义在 HTML 中,或通过 AJAX 从服务器加载数据。




    
    
    动态表格增删改
    


    

动态表格数据管理

// 初始表格及数据(使用 document.write 简化演示)
document.addEventListener('DOMContentLoaded', function() {
    let tableHTML = `
        
ID 姓名 地址 年龄 操作
1 Anu Colombo 20
`; document.getElementById('table-container').innerHTML = tableHTML; });

注意: 上述代码将表格内容插入到 table-container div 中,而不是直接使用 document.write 覆盖整个文档,这是一种更推荐的做法。

2. 核心 JavaScript 功能实现

我们将实现 addrow (添加), deleterow (删除), editrow (编辑) 和 saverow (保存) 四个核心功能。

立即学习Java免费学习笔记(深入)”;

2.1 添加行 (addrow)

addrow 函数负责获取输入框中的新数据,创建一个新的表格行,并将其插入到表格中。

function addrow(){
    var new_id = document.getElementById("new_id").value;
    var new_name = document.getElementById("new_name").value;
    var new_address = document.getElementById("new_address").value;
    var new_age = document.getElementById("new_age").value;

    if (!new_id || !new_name || !new_address || !new_age) {
        alert("所有字段都不能为空!");
        return;
    }

    var mytable = document.getElementById("TABLE");
    // 获取当前表格的行数,用于生成新的行ID
    // 注意:这里的 t_length 应该考虑表头和添加行本身
    var t_length = mytable.rows.length - 1; // 减去“添加新行”的行,确保ID递增

    // 创建新的行HTML字符串
    var newRowHTML = `
        
            ${new_id}
            ${new_name}
            ${new_address}
            ${new_age}
            
                 
                 
                
            
        `;

    // 将新行插入到“添加新行”之前
    var addRowElement = document.getElementById('add_new_row');
    addRowElement.insertAdjacentHTML('beforebegin', newRowHTML);

    // 清空输入框
    document.getElementById("new_id").value = "";
    document.getElementById("new_name").value = "";
    document.getElementById("new_address").value = "";
    document.getElementById("new_age").value = "";
}

2.2 删除行 (deleterow)

deleterow 函数通过事件对象获取被点击按钮的父元素(

一览AI绘图
一览AI绘图

一览AI绘图是一览科技推出的AIGC作图工具,用AI灵感助力,轻松创作高品质图片

下载
),再获取其父元素( ),然后从表格中移除该行。
function deleterow(buttonElement) {
    var td = buttonElement.parentNode; 
    var tr = td.parentNode;
    tr.parentNode.removeChild(tr);
}

注意: 原始代码中的 deleterow() 没有传递参数,依赖全局 event 对象。为了更好的可维护性和兼容性,我们修改为传递按钮元素本身,然后通过 parentNode 属性向上查找。

2.3 编辑行 (editrow)

editrow 函数是本教程的重点,它负责将表格单元格的静态文本内容转换为可编辑的 字段。

问题分析: 原始代码中,虽然创建了包含 标签的 HTML 字符串,但并没有将其赋值给对应的单元格的 innerHTML,导致页面上没有实际的视觉变化。

解决方案: 在创建完 input 元素的 HTML 字符串后,必须将其赋值给对应的

元素的 innerHTML 属性。
function editrow(x){
    // 1. 切换编辑和保存按钮的显示状态
    document.getElementById("edit_button"+x).style.display="none";
    document.getElementById("save_button"+x).style.display="inline-block"; // 使用 inline-block 以保持按钮在同一行

    // 2. 获取当前行的所有单元格元素
    var idCell = document.getElementById("id_row"+x);
    var nameCell = document.getElementById("name_row"+x);
    var addressCell = document.getElementById("address_row"+x);
    var ageCell = document.getElementById("age_row"+x);

    // 3. 获取当前单元格的文本内容
    var id_data = idCell.innerHTML;
    var name_data = nameCell.innerHTML;
    var address_data = addressCell.innerHTML;
    var age_data = ageCell.innerHTML;

    // 4. 将文本内容转换为包含输入框的HTML字符串
    // 注意:这里为每个输入框设置了唯一的ID,方便后续saverow函数获取值
    var id_input_html = "";
    var name_input_html = "";
    var address_input_html = "";
    var age_input_html = ""; 

    // 5. 将生成的输入框HTML字符串赋值给对应的单元格的 innerHTML
    // 这是修复原始代码中缺少的核心步骤!
    idCell.innerHTML = id_input_html;
    nameCell.innerHTML = name_input_html;
    addressCell.innerHTML = address_input_html;
    ageCell.innerHTML = age_input_html;
} 

2.4 保存行 (saverow)

saverow 函数负责在用户完成编辑后,从输入框中获取新值,更新表格单元格的文本内容,并将输入框变回静态文本。

function saverow(y){
    // 1. 从输入框中获取新值
    var id_val = document.getElementById("id_text"+y).value;
    var name_val = document.getElementById("name_text"+y).value;
    var address_val = document.getElementById("address_text"+y).value;
    var age_val = document.getElementById("age_text"+y).value;

    // 2. 更新对应单元格的 innerHTML 为新值
    document.getElementById("id_row"+y).innerHTML = id_val;
    document.getElementById("name_row"+y).innerHTML = name_val;
    document.getElementById("address_row"+y).innerHTML = address_val;
    document.getElementById("age_row"+y).innerHTML = age_val;

    // 3. 切换编辑和保存按钮的显示状态
    document.getElementById("edit_button"+y).style.display = "inline-block";
    document.getElementById("save_button"+y).style.display = "none";
}

3. 完整示例代码

将上述所有 JavaScript 函数整合到 HTML 文件的




    
    
    动态表格增删改
    


    

动态表格数据管理

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2036

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1365

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1278

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

949

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1406

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1231

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1440

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1303

2023.11.13

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

74

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.2万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 6.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号