vue elementui 实现从excel从复制多行多列后粘贴到前端界面el-table

这篇具有很好参考价值的文章主要介绍了vue elementui 实现从excel从复制多行多列后粘贴到前端界面el-table。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1、效果图

可以全部复制粘贴,也可以单独对某行、某列进行复制粘贴

从excel复制粘贴到前端页面的table上

2、实现代码

html部分:

<template>
  <div>
    <el-table
      :data="tableData"
      border
      style="width: 100%"
      :cell-class-name="getCellIndex"
      @paste.native="pasteInfo($event)"
      @cell-click="cellClick">
      <el-table-column prop="date" align="center" label="日期" width="180">
        <template slot-scope="scope">
          <el-input v-model="scope.row.date" placeholder="单行输入" clearable />
        </template>
      </el-table-column>
      <el-table-column prop="name" align="center" label="姓名" width="180">
        <template slot-scope="scope">
          <el-input v-model="scope.row.name" placeholder="单行输入" clearable />
        </template>
      </el-table-column>
      <el-table-column prop="address" align="center" label="地址">
        <template slot-scope="scope">
          <el-input v-model="scope.row.address" placeholder="单行输入" clearable />
        </template>
      </el-table-column>

      <el-table-column prop="jg" align="center" label="籍贯"></el-table-column>
      <el-table-column prop="gz" align="center" label="工作"></el-table-column>
      <el-table-column prop="xz" align="center" label="薪资"></el-table-column>

      <el-table-column prop="age" align="center" label="年龄">
        <template slot-scope="scope">
          <el-input v-model="scope.row.age" placeholder="单行输入" clearable />
        </template>
      </el-table-column>
      <el-table-column prop="sex" align="center" label="性别">
        <template slot-scope="scope">
          <el-input v-model="scope.row.sex" placeholder="单行输入" clearable />
        </template>
      </el-table-column>
      <el-table-column prop="tel" align="center" label="电话">
        <template slot-scope="scope">
          <el-input v-model="scope.row.tel" placeholder="单行输入" clearable />
        </template>
      </el-table-column>
    </el-table>
  </div>
</template>

js部分:文章来源地址https://www.toymoban.com/news/detail-758097.html

<script>
export default {
  name: 'testDemo',
  data() {
    return {
      tableData: [
        {
          date: '2016-05-02',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄',
          jg: '北京',
          gz: '学生',
          xz: '0',
          age: 18,
          sex: '女',
          tel: '13112345678',
        }, {
          date: '2016-05-04',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1517 弄',
          jg: '上海',
          gz: '销售',
          xz: '10000',
          age: 19,
          sex: '男',
          tel: '13112345678',
        }, {
          date: '2016-05-01',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1519 弄',
          jg: '上海',
          gz: '行政',
          xz: '5000',
          age: 31,
          sex: '男',
          tel: '13112345678',
        }, {
          date: '2016-05-03',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1516 弄',
          jg: '江苏',
          gz: '做生意',
          xz: '50000+',
          age: 48,
          sex: '男',
          tel: '13112345678',
        }
      ],
      rowIndex: undefined,
      columnIndex: undefined,
    }
  },
  methods: {
    /** 设置行、列索引 */
    getCellIndex: function ({ row, column, rowIndex, columnIndex }) {
      row.index = rowIndex;
      column.index = columnIndex;
    },
    /** 点击单元格 */
    cellClick(row, column, cell, event) {
      // console.log(row, column, cell, event);
      this.rowIndex = row.index
      this.columnIndex = column.index
    },
    /** 复制粘贴 */
    pasteInfo(e) {
      try {
        e.preventDefault(); //阻止默认粘贴事件
        e.stopPropagation(); //阻止事件冒泡

        var data = null;
        var clipboardData = e.clipboardData || window.clipboardData; // IE
        if (!clipboardData) {
          //chrome
          clipboardData = e.originalEvent.clipboardData;
        }
        data = clipboardData.getData("Text"); //复制过来的内容
        //首先对源头进行解析
        if (data && !data.includes('\r\n')) { // 单独复制文本,不是复制单个单元格
          data = data+'\r\n'
        }
        var rowStrArray = data.split("\r\n"); //拆成多行
        let rows = [];
        for (var i = 0; i < rowStrArray.length-1; i++) {
          var row = [];
          var tdStrArray = rowStrArray[i].split("\t"); //按列拆分
          for (var j = 0; j < tdStrArray.length; j++) {
            row.push(tdStrArray[j]);
          }
          rows.push(row);
        }
        // console.log(rows,'---------rows')

        let emptyObj = { //需要复制粘贴的key值列
          date: undefined,
          name: undefined,
          address: undefined,
          jg: undefined,
          gz: undefined,
          xz: undefined,
          age: undefined,
          sex: undefined,
          tel: undefined,
        }
        for (var j = 0; j < rows.length; j++) {
          if(this.rowIndex+j > this.tableData.length - 1){
            break
          }
          let item = {}
          item = JSON.parse(JSON.stringify(this.tableData[this.rowIndex+j]))
          let num = 0
          let numFlag = 0 //从哪一列开始粘贴:全部列都可以粘贴(即从第0列可以粘贴)
          for (var key in emptyObj) {
            if (!rows[j][num]) {
              break
            }
            // console.log('numFlag--', numFlag, 'this.columnIndex--', this.columnIndex, 'num-', num);
            if (this.columnIndex <= numFlag) {
              // 针对不能修改的列字段做处理,可以复制粘贴的列才做赋值。根据需求加下面的if判断
              if (key !== 'jg' && key !== 'gz' && key !== 'xz') {
                item[key] = rows[j][num]
              }
              num = num + 1
            }
            numFlag = numFlag + 1
          }
          this.$set(this.tableData, this.rowIndex+j, item)
        }
      } catch(err) {
        this.$message.error('请选择粘贴位置')
      }
    },
  }
}
</script>

到了这里,关于vue elementui 实现从excel从复制多行多列后粘贴到前端界面el-table的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Vue-Clipboard3:轻松实现复制到粘贴板功能

    在现代Web开发中,剪贴板操作变得越来越重要。用户经常需要在浏览器中进行复制、粘贴等操作,而这些操作可以通过JavaScript实现。Vue-Clipboard3是一个基于Clipboard.js的粘贴板操作库,使用 Vue-Clipboard3 可以在Vue 3(composition api)中轻松复制到粘贴板,它使得在Vue3应用程序中进行

    2024年01月20日
    浏览(45)
  • SQL实现一行数据分组后转多行多列

    在统计一些指标时,通常会有多个指标需要分组进行聚合,但是 数据源的粒度可能并非是指标分组的粒度 。举个例子,比如从访客表中提取访客的数据,每行数据有每个平台的首次访问时间;另外要做一个平台统计表,其中的一个指标统计的是各个平台近1天、7天、30天的新

    2024年02月14日
    浏览(35)
  • 按键精灵之自动复制粘贴到Excel单元格中

    本文将分享按键精灵(Q语言)的一个脚本使用,自动实现从输出窗口A中,将输出的数据内容复制,然后粘贴到事先设置好的Excel表格B中。 需n次重复执行复制粘贴操作至Excel表格的不同单元格中(依次)。注意:因使用屏幕坐标进行定位,因此不同分辨率的桌面,运行脚本前

    2024年02月12日
    浏览(65)
  • excel表中复制粘贴有隐藏行的情况

    一、原始数据,没有任何隐藏的情况: 二、隐藏3、4行: 这种情况下: 三、我想复制粘贴出可见的内容,全选,ctrl+c复制 四、ctrl+v粘贴到别处,结果却是 发现隐藏的行也被复制粘贴出来了。并不是我们想要的。 解决办法: 在第“三”步中,全选可见内容后, 按alt+; ,即可

    2024年02月09日
    浏览(45)
  • 用python复制粘贴excel指定单元格(可保留格式)

    近期学习了openpyxl的用法,发现居然没有【复制、粘贴】这么基础的函数。而且若要用python带格式复制粘贴指定区域的单元格,参考资料更少。 于是参考各路大佬的笔记,整合如下。 本代码只完成一次复制粘贴,各位可根据自己的需要加以利用,比如:可搭配遍历文件等实现

    2024年02月13日
    浏览(41)
  • 信创办公–基于WPS的EXCEL最佳实践系列 (数据整理复制粘贴)

    信创办公–基于WPS的EXCEL最佳实践系列 (数据整理复制粘贴) 数据的整理复制粘贴等在日常的工作中经常使用。本章内容主要学习对数据进行查找与替换、整理、编辑、拆分多列和应用数字格式,数据处理过程中的步骤,可以帮助我们更好的学习、组织及理解数据。 (1)选

    2024年02月07日
    浏览(50)
  • 前端vue+elementui导出复杂(单元格合并,多级表头)表格el-table转为excel导出

    需求 :前端对el-table表格导出 插件 : npm install xlsx -S npm install file-saver --save 原理 :直接导出el-table的表格里面的数据,这样就会存在缺点,只会导出当前页面的数据,如果需要导出全部数据,可以自己重新渲染一个全部数据不可见的el-table表格,来导出就可以了 扩展 :经过

    2024年02月04日
    浏览(66)
  • [office] Excel中进行复制粘贴公式时数值不变化的解决方法 #笔记#媒体

    Excel中进行复制粘贴公式时数值不变化的解决方法 excel表中复制粘贴公式时数值不变化解决方法终结版,如何解决在计算的过程中,设置好了公式,希望复制公式粘贴到下面的很多单元格中,今天,小编就教大家在Excel中进行复制粘贴公式时数值不变化的解决方法。 Excel中进行

    2024年02月21日
    浏览(102)
  • Vue+ElementUI实现选择指定行导出Excel

    这里记录一下,今天写项目时 的一个需求,就是通过复选框选中指定行然后导出表格中选中行的Excel表格 然后这里介绍一个工具箱(模板): vue-element-admin 将它拉取后,运行就可以看到如下界面: 这里面的很多功能都已经实现了,比如上图我标记的导出Excel、Zip、PDF等。。。

    2024年02月13日
    浏览(35)
  • Hive多行转多列,多列转多行

    原始数据表 目标结果表 分析:目标表中的a和b是用分组形成,所以groupby字段选用原始表中col1,c、d、e是原始表中的行值,在目标表中成了列名,目标表中可以采用as做列名自定义,当原始表中的某一字段值等于某一特定值时,人为定义为结果表中的列名。 SQL实现 总结:多行

    2024年02月12日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包