HTML页面模拟了一个类似Excel的表格在线diy修改表格内容

html实现在线表格编辑,可以修改每个表格内容,并且可以添加行和列

这个HTML页面模拟了一个类似Excel的表格,可以添加和删除行和列,并且可以编辑每个表格的内容。通过点击按钮可以添加新的行和列,通过按钮可以删除最后一行和最后一列。每个单元格都可以通过直接点击并编辑来修改内容。

实现代码

html 复制代码
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>Excel-like Table</title>
    <style>
        table {
            border-collapse: collapse;
            table-layout: fixed;
            width: 100%;
        }
        th, td {
            border: 1px solid black;
            padding: 5px;
            text-align: center;
        }
        .addRow, .addColumn, .deleteRow, .deleteColumn {
            margin-bottom: 10px;
        }
        button {
            padding: 5px 10px;
        }
    </style>
</head>
<body>
<div>
    <button class="addRow" onclick="addRow()">添加行</button>
    <button class="addColumn" onclick="addColumn()">添加列</button>
    <button class="deleteRow" onclick="deleteRow()">删除行</button>
    <button class="deleteColumn" onclick="deleteColumn()">删除列</button>
    <button class="saveData" onclick="saveData()">保存数据</button>
</div>
<table id="excelTable">
    <thead>
    <tr>
        <th contenteditable="true"></th>
        <th contenteditable="true">A</th>
        <th contenteditable="true">B</th>
        <th contenteditable="true">C</th>
        <th contenteditable="true">D</th>
    </tr>
    </thead>
    <tbody>
    <tr>
        <th contenteditable="true">1</th>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
    </tr>
    <tr>
        <th contenteditable="true">2</th>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
    </tr>
    <tr>
        <th contenteditable="true">3</th>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
    </tr>
    <tr>
        <th contenteditable="true">4</th>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
        <td contenteditable="true"></td>
    </tr>
    </tbody>
</table>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script>
    function addRow() {
        var table = document.getElementById("excelTable");
        var row = table.insertRow(-1);
        var rowIndex = table.rows.length - 2;
        var cell0 = row.insertCell(0);
        cell0.innerHTML = rowIndex;
        cell0.contentEditable = true;
        for (var i = 1; i < table.rows[1].cells.length; i++) {
            var cell = row.insertCell(i);
            cell.contentEditable = true;
        }
    }
    function addColumn() {
        var table = document.getElementById("excelTable");
        for (var i = 0; i < table.rows.length; i++) {
            var cell = table.rows[i].insertCell(-1);
            cell.contentEditable = true;
            if (i === 0) {
                var columnIndex = table.rows[i].cells.length - 2;
                cell.innerHTML = String.fromCharCode(65 + columnIndex);
                cell.contentEditable = true;
            }
        }
    }
    function deleteRow() {
        var table = document.getElementById("excelTable");
        if (table.rows.length > 2) {
            table.deleteRow(-1);
        }
    }
    function deleteColumn() {
        var table = document.getElementById("excelTable");
        if (table.rows[0].cells.length > 2) {
            for (var i = 0; i < table.rows.length; i++) {
                table.rows[i].deleteCell(-1);
            }
        }
    }
    function saveData() {
        var tableData = [];
        var table = document.getElementById("excelTable");
        var tableHeaders = [];
        for (var i = 0; i < table.rows[0].cells.length; i++) {
            tableHeaders.push(table.rows[0].cells[i].innerHTML);
        }
        tableData.push(tableHeaders);
        for (var i = 1; i < table.rows.length; i++) {
            var rowData = [];
            for (var j = 0; j < table.rows[i].cells.length; j++) {
                rowData.push(table.rows[i].cells[j].innerHTML);
            }
            tableData.push(rowData);
        }
        $.ajax({
            url: "test5.php",
            type: "POST",
            data: { tableData: JSON.stringify(tableData) },
            success: function(response) {
                alert("Data saved successfully!");
            }
        });
    }
</script>
</body>
</html>

使用ajax请求将这个数组传递给名为".php"的文件进行处理。 注意,你需要自己创建一个".php"文件,并在其中编写相应的程序来保存数据。

相关推荐
高山我梦口香糖30 分钟前
[react]searchParams转普通对象
开发语言·前端·javascript
信号处理学渣1 小时前
matlab画图,选择性显示legend标签
开发语言·matlab
红龙创客1 小时前
某狐畅游24校招-C++开发岗笔试(单选题)
开发语言·c++
jasmine s1 小时前
Pandas
开发语言·python
biomooc1 小时前
R 语言 | 绘图的文字格式(绘制上标、下标、斜体、文字标注等)
开发语言·r语言
骇客野人1 小时前
【JAVA】JAVA接口公共返回体ResponseData封装
java·开发语言
black^sugar1 小时前
纯前端实现更新检测
开发语言·前端·javascript
404NooFound2 小时前
Python轻量级NoSQL数据库TinyDB
开发语言·python·nosql
用余生去守护2 小时前
python报错系列(16)--pyinstaller ????????
开发语言·python
数据小爬虫@2 小时前
利用Python爬虫快速获取商品历史价格信息
开发语言·爬虫·python