我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vue实现excel表格的导入导出的示例

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vue实现excel表格的导入导出的示例

一、下载xlsx插件

npm i xlsx

二、通过element-ui组件的upload组件上传文件

  <el-upload
    class="upload-demo"
    action //必选参数,上传的地址,这里我们不写地址自定义上传
    accept=".xlsx,.xls"  //文件类型
    :auto-upload="false" //是否在选取文件后立即进行上传
    :show-file-list="false" //是否显示已上传文件列表
    :on-change="handleChange" //文件状态改变时的钩子,添加文件、上传成功和上传失败时都会被调用
  >
    <el-button type="primary">选择文件</el-button>
  </el-upload>

三、把选择的Excel文件把文件内容转化为二进制

//把二进制文件进行读取
export function readFile(file) {
  return new Promise((resolve, reject) => {
    // FileReader主要用于将文件内容读入内存,通过一系列异步接口,可以在主线程中访问本地文件.
    let reader = new FileReader();
    // 异步按字节读取文件内容,结果为文件的二进制串
    reader.readAsBinaryString(file);
    reader.onload = (ev) => {
      resolve(ev.target.result);
    };
  });
}

四、通过插件中的xlsx.read()读取二进制数据

//选择文件
const handleChange = async function (e) {
    const file = e.raw; //选择的文件内容
    let data = await readFile(file); //将内容转化为二进制
    let workbook = xlsx.read(data, { type: "binary" });  //通过插件读取二进制数据 binary二进制
}

五、通过xlsx.utils.sheet_to_json()把表格一中的数据转化为JSON格式

  //表格目录一中的数据
  let worksheet = workbook.Sheets[workbook.SheetNames[0]];
  //把数据转化为json数据格式
  data = xlsx.utils.sheet_to_json(worksheet);

六、把读取的JSON数据转化为可以传递给服务器的数据

 //把读取的数据变为最后可以传递给服务器的数据(所在地=>address,学校名称=>shcoolName......)
  let arr = [];
  data.forEach((item) => {
    let obj = {};
    for (let key in character) {
      //  hasOwnProperty() 方法会返回一个布尔值,指示对象自身属性中是否具有指定的属性(也就是,是否有指定的键)
      //  即使属性的值是 null 或 undefined,只要属性存在,hasOwnProperty 依旧会返回 true。
      //  判断是否有规定的属性没有就终止执行
      if (!character.hasOwnProperty(key)) break;
      let v = character[key],
        text = v.text,
        type = v.type;
      v = item[text] || "";
      //将数据转化为对应的数据类型 不符合的话不做操作
      type === "string" ? (v = String(v)) : null;
      type === "number" ? (v = Number(v)) : null;
      obj[key] = v;
    }
    arr.push(obj);
  });
  //给用户一点延迟
  await delay(100);
  //将导入数据展示到页面中
  result.tableData = arr;

导出

// 1.把数据转化为表格名称对应
  let arr = result.tableData.map((item) => {
    return {
      办学层次: item.levels,
      备注: item.message,
      学校名称: item.schoolName,
      所在地: item.address,
    };
  });
  //2.用于将 JSON 数据转换为 Excel 工作表中的单元格数据。
  let sheet = xlsx.utils.json_to_sheet(arr);
  //3.用于创建一个新的 Excel 工作簿对象它返回一个空白的工作簿,可以向其中添加工作表和单元格数据。
  let book = xlsx.utils.book_new();
  //4.用于向现有的 Excel 工作簿对象(Workbook)中添加一个新的工作表
  // book_append_sheet(wb, sheet, name=None)
  //参数wb是要将工作表添加到的 Workbook 对象;sheet 参数是要添加的 Worksheet 对象;name 参数是要为工作表指定的名称(如果未指定,则使用默认名称)
  xlsx.utils.book_append_sheet(book, sheet, "sheet1");
  //5.用于将 Excel 工作簿下载到本地文件系统中 book要下载的Eceial表格,第二个参数是表格名称
  xlsx.writeFile(book, `user${new Date().getTime()}.xls`);

到此这篇关于vue实现excel表格的导入导出的示例的文章就介绍到这了,更多相关vue excel导入导出内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vue实现excel表格的导入导出的示例

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

vue实现excel表格的导入导出的示例

本文主要介绍了vue实现excel表格的导入导出的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-15

vue怎么实现excel表格的导入导出

这篇文章主要介绍“vue怎么实现excel表格的导入导出”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue怎么实现excel表格的导入导出”文章能帮助大家解决问题。一、下载xlsx插件npm i
2023-07-06

Spring 实现excel及pdf导出表格示例

整理文档,搜刮出一个Spring 实现excel及pdf导出表格的代码,稍微整理精简一下做下分享。excel 导出:package light.mvc.utils.excel; import java.util.Date; import
2023-05-31

Java如何利用POI实现导入导出Excel表格

这篇文章主要介绍“Java如何利用POI实现导入导出Excel表格”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java如何利用POI实现导入导出Excel表格”文章能帮助大家解决问题。一、Java
2023-07-06

《springboot中实现excel表格导出》

《springboot中实现excel表格导出》 简介 在Spring Boot中,实现Excel表格导出的方式有很多种,以下是几种常见的方法: 使用Apache POI:Apache POI是一个开源的Java API,用于处理Micro
2023-08-23

Java+element实现excel的导入和导出

本文主要介绍了Java+element实现excel的导入和导出,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-16

使用EasyExcel实现Excel的导入导出

文章目录 前言一、EasyExcel是什么?二、使用步骤1.导入依赖2.编写文件上传配置3.配置表头对应实体类4.监听器编写5.控制层6.前端代码 总结 前言 在真实的开发者场景中,经常会使用excel作为数据的载体,进行
2023-08-17

MySQLWorkbench导入excel数据的实现示例

本文主要介绍了MySQLWorkbench导入excel数据的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-01-05

php使用PhpSpreadsheet导出Excel表格的实例详解

本教程详细介绍了如何使用PhpSpreadsheet从PHP导出Excel表格。通过引入库并实例化对象,您可以创建表格数据并将其插入表格中。设置列宽、字体、边框以及标题和页眉页脚,以美化表格。最后,通过设置打印选项并使用导出函数将表格保存为Excel文件。本教程提供了完整的示例代码,供您参考并实现自己的导出功能。
php使用PhpSpreadsheet导出Excel表格的实例详解
2024-04-02

编程热搜

目录