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

26 篇文章 0 订阅
25 篇文章 0 订阅

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

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

实现代码 

<!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"文件,并在其中编写相应的程序来保存数据。

  • 10
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

PHP隔壁老王邻居

啦啦啦啦啦

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值