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

 更新时间:2023年04月11日 09:50:31   作者:filter忠实信徒  
本文主要介绍了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导入导出内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue+element树形选择器组件封装和使用方式

    vue+element树形选择器组件封装和使用方式

    这篇文章主要介绍了vue+element树形选择器组件封装和使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2020-04-04
  • Vue中设置登录验证拦截功能的思路详解

    Vue中设置登录验证拦截功能的思路详解

    今天在做vue和springboot交互的一个项目的时候,想要基于前端实现一些只有登录验证之后才能访问某些页面的操作,所以在这里总结一下实现该功能的一个解决方案
    2021-10-10
  • element-ui多文件上传的实现示例

    element-ui多文件上传的实现示例

    这篇文章主要介绍了element-ui多文件上传的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • vue2.* element tabs tab-pane 动态加载组件操作

    vue2.* element tabs tab-pane 动态加载组件操作

    这篇文章主要介绍了vue2.* element tabs tab-pane 动态加载组件操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • vue3 使用 vue3-video-play实现在线视频播放

    vue3 使用 vue3-video-play实现在线视频播放

    这篇文章主要介绍了vue3 使用 vue3-video-play 进行在线视频播放,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06
  • 浅谈vue-props的default写不写有什么区别

    浅谈vue-props的default写不写有什么区别

    这篇文章主要介绍了浅谈vue-props的default写不写有什么区别,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • vue大文件分片上传之simple-uploader.js的使用

    vue大文件分片上传之simple-uploader.js的使用

    本文主要介绍了vue大文件分片上传之simple-uploader.js的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05
  • Vue2.x响应式简单讲解及示例

    Vue2.x响应式简单讲解及示例

    这篇文章主要介绍了Vue2.x响应式及简单的示例,应用了简单的源代码进行讲解,感兴趣的小伙伴可以参考一下,希望可以帮助到你
    2021-08-08
  • Vue过滤器filters的用法及时间戳转换问题

    Vue过滤器filters的用法及时间戳转换问题

    Vue的filters过滤器是比较常见的一个知识点,下面我将结合时间戳转换的例子带你快速了解filters的用法,感兴趣的朋友一起看看吧
    2021-09-09
  • Vue2.0学习系列之项目上线的方法步骤(图文)

    Vue2.0学习系列之项目上线的方法步骤(图文)

    这篇文章主要介绍了Vue2.0学习系列之项目上线的方法步骤(图文),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09

最新评论