html实现粘贴excel数据,在页面表格中复制

录入数据时,有时候需要把excel中的数据一条条粘贴到页面中,当数据量过多时,这种操作很令人崩溃。本篇文章实现了从excel复制好多行数据后,可在页面粘贴的功能

具体实现代码

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>可编辑表格</title>
<style>
  #textarea {
    width: 80%;
    min-height: 100px;
    border: 1px solid #ccc;
  }
  table {
    width: 100%;
    border-collapse: collapse;
  }
  th, td {
    border: 1px solid #ccc;
    padding: 8px;
    text-align: left;
  }
  th {
    background-color: #f2f2f2;
  }
</style>
</head>
<body>
  <textarea id="textarea"></textarea>
  <table id="myTable">
    <thead>
      <tr>
        <th>姓名</th>
        <th>年龄</th>
        <th>职业</th>
      </tr>
    </thead>
    <tbody>
      <tr>
        <td>张三</td>
        <td>30</td>
        <td>程序员</td>
      </tr>
      <tr>
        <td>李四</td>
        <td>28</td>
        <td>设计师</td>
      </tr>
    </tbody>
  </table>

  <script>
    document.addEventListener('DOMContentLoaded', function() {
      const inputElement = document.getElementById('textarea');

      function handlePasteEvent(event) {
        // event.preventDefault(); // 可选:阻止默认粘贴行为

        // 获取粘贴板数据
        const clipboardData = event.clipboardData || window.clipboardData;
        const pastedData = clipboardData.getData('Text');

        // 初始化用于存储解析后的数据的数组
        let arr = [];
        try {
          arr = pastedData.split('\n')
            .filter(item => item !== '') // 兼容Excel行末\n,防止出现多余空行
            .map(item => item.split('\t')) // 将每行按制表符分割成列
            .map(item => {
              // 去掉每列中的\r字符,使用模板字符串
              return item.map(str => str.replace(/\r/g, ''));
            });
        } catch (error) {
          console.error("Error parsing pasted data:", error);
          return; // 在遇到异常时终止处理
        }
        if (arr.length === 0) {
          console.warn("Pasted data is empty or in an unrecognized format.");
          return;
        }

        const table = document.getElementById("myTable");
        const cells = table.rows.item(0).cells.length; // 表格的列数

        // 创建一个文档片段,用于批量添加新行到DOM中,减少重绘次数
        const fragment = document.createDocumentFragment();

        arr.forEach(item => {
          const newRow = document.createElement("tr");
          for (let i = 0; i < cells; i++) {
            const newCell = document.createElement("td");
            newCell.textContent = item[i] || '';
            newRow.appendChild(newCell);
          }
          fragment.appendChild(newRow); // 先将新行添加到文档片段中
        });

        table.appendChild(fragment); // 最后将整个文档片段一次性添加到表格中
      }
      // 添加粘贴事件监听器
      inputElement.addEventListener('paste', handlePasteEvent);
    });
  </script>
</body>
</html>

效果图

相关推荐
光影少年3 小时前
angular生态及学习路线
前端·学习·angular.js
无尽夏_5 小时前
HTML5(前端基础)
前端·html·html5
Jagger_5 小时前
敏捷开发流程-精简版
前端·后端
FIN66686 小时前
昂瑞微冲刺科创板:创新驱动,引领射频芯片国产化新征程
前端·安全·前端框架·信息与通信·芯片
GISer_Jing6 小时前
ByteDance——jy真题
前端·javascript·面试
睡美人的小仙女1276 小时前
浏览器为何屏蔽本地文件路径?
前端
真的想不出名儿6 小时前
Vue 中 props 传递数据的坑
前端·javascript·vue.js
FIN66686 小时前
昂瑞微:深耕射频“芯”赛道以硬核实力冲刺科创板大门
前端·人工智能·科技·前端框架·信息与通信·智能
阳光阴郁大boy6 小时前
星座运势网站技术解析:从零打造现代化Web应用
前端·javascript
烛阴6 小时前
武装你的Python“工具箱”:盘点10个你必须熟练掌握的核心方法
前端·python