element 导入excel
导入依赖
npm install -S file-saver xlsx
npm install -D script-loader
html页面:
<input
ref="excel-upload-input"
class="excel-upload-input"
type="file"
accept=".xlsx, .xls"
@change="handleClick"
/>
<div
class="drop"
@drop="handleDrop"
@dragover="handleDragover"
@dragenter="handleDragover"
>
<el-button
:loading="loading"
class="eidt"
size="mini"
type="primary"
@click="handleUpload">导入</el-button>
</div>
<el-table
id="tableId"
:data="tableData"
border
highlight-current-row
style="width: 100%; margin-top: 20px"
>
<el-table-column
v-for="item of tableHeader"
:key="item"
:prop="item"
:label="item"
/>
</el-table>
script代码:
<script>
import * as XLSX from "xlsx";export default {.......methods:{
// 点击导入handleDrop(e) {e.stopPropagation();e.preventDefault();if (this.loading) return;const files = e.dataTransfer.files;if (files.length !== 1) {this.$message.error("仅支持单个上传一个文件");return;}const rawFile = files[0]; // 获取文件信息if (!this.isExcel(rawFile)) {//是不是excel文件this.$message.error("仅支持 .xlsx, .xls, .csv 文件格式上传");return false;}this.upload(rawFile);e.stopPropagation();e.preventDefault();},handleDragover(e) {e.stopPropagation();e.preventDefault();e.dataTransfer.dropEffect = "copy";},handleUpload() {this.$refs["excel-upload-input"].click(); //触发表单上传事件,跳出选择文件框},handleClick(e) {// console.log(e);const files = e.target.files;const rawFile = files[0]; // only use files[0]if (!rawFile){this.$notify.error({title: '错误',message: '无法读取该文件',duration: 1000});return}else if(!this.isExcel(rawFile)){this.$notify.error({title: '错误',message: "仅支持 .xlsx, .xls, .csv 文件格式上传",duration: 1000});return}this.upload(rawFile);},upload(rawFile) {this.$refs["excel-upload-input"].value = null; // fix can't select the same excelif (!this.beforeUpload) {this.readerData(rawFile);return;}const before = this.beforeUpload(rawFile); //判断文件上传大小if (before) {this.readerData(rawFile); //把excel转化成数组}},beforeUpload(file) {const isLt1M = file.size / 1024 / 1024 < 1;if (isLt1M) {return true;}this.$message({message: "请不要上传大于1M的文件",type: "warning",});return false;},readerData(rawFile) {this.loading = true;return new Promise((resolve, reject) => {const reader = new FileReader();reader.readAsArrayBuffer(rawFile);//参数可以是 Blob 或者 File 对象异步结果将在onload 事件中体现reader.onload = (e) => {const data = e.target.result;console.log(data);const workbook = XLSX.read(data, { type: "array" });console.log("workbook", workbook);//看下图const firstSheetName = workbook.SheetNames[0];// console.log("firstSheetName",firstSheetName);// "SheetJS" 取出工作表名称const worksheet = workbook.Sheets[firstSheetName]; //取出工作表名称对应的表格数据const header = this.getHeaderRow(worksheet); //表头名// console.log("header",header);const results = XLSX.utils.sheet_to_json(worksheet); //输出数据,除去表头//{timestamp: "2017-01-01 07:37:20",title: "Mtiwxlj Cqcdg Hvbjijr Vgmeey Wwznq Ljjnkvbz",//type: "US",importance: 2,status: "draft"} results的其中一列数据this.tableData = results;this.tableHeader = header;this.loading = false;this.doTableData()resolve();};});},getHeaderRow(sheet) {const headers = [];const range = XLSX.utils.decode_range(sheet["!ref"]); //!ref: "A1:E21"// console.log(range);// s: {c: 0, r: 0} 开始为A1// e: {c: 4, r: 20} 结束为 E21let C;const R = range.s.r;/* start in the first row */for (C = range.s.c; C <= range.e.c; ++C) {/* walk every column in the range */const cell = sheet[XLSX.utils.encode_cell({ c: C, r: R })];// console.log(cell); A1的对象的值/* find the cell in the first row */let hdr = "UNKNOWN " + C; // <-- replace with your desired defaultif (cell && cell.t){//不为空才push表头hdr = XLSX.utils.format_cell(cell);headers.push(hdr);}}return headers;},isExcel(file) {return /\.(xlsx|xls|csv)$/.test(file.name);},.......}</script>
参考https://blog.csdn.net/NancyFyn/article/details/125886627
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律