element-plus 导入导出

操作

// 参考版本 "xlsx": "^0.18.5"

npm i xlsx

导入

创建文件 放入下方js

复制代码
/* 读取文件 */
export const readFile = (file) => {
    return new Promise(resolve => {
        // FileReader 对象允许Web应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,使用 File 或 Blob 对象指定要读取的文件或数据。
        let reader = new FileReader()
        // 该方法用于将File对象转化为二进制文件
        reader.readAsBinaryString(file)
        // 当把文件所有数据加载完毕后,把数据传给promise的下一步
        reader.onload = ev => {
            resolve(ev.target.result)
        }
    }

创建面板

复制代码
<script setup>
import * as xlsx from "xlsx"
import { readFile } from "@/utils/readFile.js";
import { ref } from 'vue'
const tableData = ref([])
const onChange = async (file) => {
    // console.log('file',file);
    // 获取上传excel的文件数据
    let dataBinary = await readFile(file.raw);
    // 获取工作簿对象
    let workBook = xlsx.read(dataBinary, { type: "binary", cellDates: true });
    // 获取第一个工作表的数据
    let workSheet = workBook.Sheets[workBook.SheetNames[0]];
    // 把工作表数据转为json
    const data = xlsx.utils.sheet_to_json(workSheet);
    //把json传给tableData
    tableData.value = data;
}
</script>
<template>
    <div class="import">
        <!--
            注意:
                1. action为空
                2. 添加 :auto-upload="false" ,阻止自动上传
                3. 事件监听 on-change
         -->
        <el-upload class="upload-demo" action='' :auto-upload="false" :on-change="onChange">
            <el-button type="primary">Click to upload</el-button>
        </el-upload>

        <!-- 表格 -->
        <el-table :data="tableData" style="width: 100%">
            <el-table-column prop="username" label="用户名" width="180">
            </el-table-column>
            <el-table-column prop="age" label="年龄" width="180"> </el-table-column>
            <el-table-column prop="score" label="分数"> </el-table-column>
        </el-table>
    </div>
</template>
<style lang="scss" scoped></style>

导出

把导出js放入文件中

复制代码
import * as XLSX from "xlsx";
//把json数据导出到excel文件中
export function export_excel(excelData, fileName) {
  // 将数据写入表格中
  const data = XLSX.utils.json_to_sheet(excelData);
  // 创建工作簿
  const wb = XLSX.utils.book_new();
  // 将工作表放入工作簿中
  XLSX.utils.book_append_sheet(wb, data, "data");
  // 生成文件并下载
  XLSX.writeFile(wb, fileName + ".xlsx");
}

//把英文表头换为中文
export function convert_excel_data(excelData, tHeader) {
  return excelData.map((item) => {
    const obj = {};
    for (const k in item) {
      if (tHeader[k]) {
        obj[tHeader[k]] = item[k];
      }
    }
    return obj;
  });
}});
}

导出面板

复制代码
<script setup>
import { convert_excel_data,export_excel } from "@/utils/exportExcel.js";
//导出Excel表格的表头设置
const jsonFields = {
    'type': '序号',
    'userName': '姓名',
    'age': '年龄',
    'phone': '手机号',
    'createTime': '注册时间',
}
//json数据
const tableData = [
    { "userName": "张三", "age": 18, "phone": 15612345612, "createTime": "2019-10-22" },
    { "userName": "李四", "age": 17, "phone": 15612345613, "createTime": "2019-10-23" },
    { "userName": "王五", "age": 19, "phone": 15612345615, "createTime": "2019-10-25" },
    { "userName": "赵六", "age": 18, "phone": 15612345618, "createTime": "2019-10-15" }
]
// 导出excel
function exportExcel(){
   //转换为中文表头
   const excelData = convert_excel_data(tableData, jsonFields);
   // 导出文件 '文件列表.xlsx'
   export_excel(excelData,"文件列表");
}
</script>
<template>
      <div class="export-excel">
         <el-button @click="exportExcel">导出excel</el-button>
      </div>
</template>
<style lang="scss" scoped></style>
相关推荐
新生GIS3 天前
arcgis-空间矫正工具(将下发数据A的信息放置原始数据B的原始信息并放置到成果数据C中,主要按下发数据A的范围)
arcgis
新生GIS6 天前
arcgis-提取范围中最大占比面积的信息或唯一值
arcgis
圆周率的后六位6 天前
GIS相关调研
arcgis·gis·supermap·gisbox·gis组件
tomelrg7 天前
多台服务器批量发布arcgisserver服务并缓存切片
服务器·python·arcgis
FL16238631298 天前
windows下ArcGIS 10.8.2下载安装教程
arcgis
allenjiao15 天前
Cesium粒子系统模拟风场动态效果
javascript·arcgis·gis·webgl·cesium·三维·风场
杨超越luckly16 天前
HTML应用指南:利用GET请求获取全国Apple Store 零售店位置信息
大数据·前端·arcgis·html·数据可视化·门店
典学长编程17 天前
前端开发(HTML,CSS,VUE,JS)从入门到精通!第八天(Vue框架及其安装)(完结篇) 重点 ! ! !
arcgis·vue·vue路由·vue脚手架·router
Wild Iris19 天前
【ArcGIS】分区统计中出现Null值且Nodata无法忽略的问题以及shp擦除(erase)的使用——以NDVI去水体为例
arcgis
新中地GIS开发老师21 天前
2025Mapbox零基础入门教程(14)定位功能
前端·javascript·arcgis·gis·mapbox·gis开发·地理信息科学