摘要:前言業務場景由前臺導入表格,獲取批量數據。根據一個數組導出表格。每一個值是個對象,包含了兩個屬性。由于本人將和放到了同一級,這里引入是這樣的。這幾個文件不支持引入,所以需要來將他們掛載到全局環境下。若不足之處,歡迎大家指出,共勉。
1 前言 1.1 業務場景
由前臺導入Excel表格,獲取批量數據。
根據一個數組導出Excel表格。
2 實現原理 2.1 引入工具庫file-saver、xlsx、script-loader
npm install -S file-saver xlsx
npm install -D script-loader
2.2 導入Excel 2.2.1 Element 上傳控件點擊上傳 只 能 上 傳 xlsx / xls 文 件
limitUpload = 1限制只能上傳1個文件
accept為默認打開的可上傳的文件格式
handleChange(file, fileList){ this.fileTemp = file.raw }, handleRemove(file,fileList){ this.fileTemp = null },
fileTemp這里定義了一下變量,指向最新上傳的附件,起始定義為null。
這里發現控件file.raw是我們要用的File類型。
2.2.2 導入判斷if(this.fileTemp){ if((this.fileTemp.type == "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet") || (this.fileTemp.type == "application/vnd.ms-excel")){ this.importfxx(this.fileTemp) } else { this.$message({ type:"warning", message:"附件格式錯誤,請刪除后重新上傳!" }) } } else { this.$message({ type:"warning", message:"請上傳附件!" }) }2.2.3 導入函數
importfxx(obj) { let _this = this; // 通過DOM取文件數據 this.file = obj var rABS = false; //是否將文件讀取為二進制字符串 var f = this.file; var reader = new FileReader(); //if (!FileReader.prototype.readAsBinaryString) { FileReader.prototype.readAsBinaryString = function(f) { var binary = ""; var rABS = false; //是否將文件讀取為二進制字符串 var pt = this; var wb; //讀取完成的數據 var outdata; var reader = new FileReader(); reader.onload = function(e) { var bytes = new Uint8Array(reader.result); var length = bytes.byteLength; for(var i = 0; i < length; i++) { binary += String.fromCharCode(bytes[i]); } var XLSX = require("xlsx"); if(rABS) { wb = XLSX.read(btoa(fixdata(binary)), { //手動轉化 type: "base64" }); } else { wb = XLSX.read(binary, { type: "binary" }); } outdata = XLSX.utils.sheet_to_json(wb.Sheets[wb.SheetNames[0]]);//outdata就是你想要的東西 this.da = [...outdata] let arr = [] this.da.map(v => { let obj = {} obj.code = v["設備ID"] obj.type = v["設備型號"] arr.push(obj) }) return arr } reader.readAsArrayBuffer(f); } if(rABS) { reader.readAsArrayBuffer(f); } else { reader.readAsBinaryString(f); } },
arr就是我們要的結果,是一個數組。每一個值是個對象,包含了code type兩個屬性。
excel中格式為橫向 設備ID 和 設備型號。
2.3 導出Excel 2.3.1 引入JS文件可參考下載地址:- github
將其中的2個JS文件放入到自己的工程中。
2.3.2 修改JS文件中地址
打開Export2Excel.js,會出現如上圖所示。由于本人將Blob.js和Export2Excel.js放到了同一級,這里引入是這樣的。
這幾個文件不支持import引入,所以需要script-loader來將他們掛載到全局環境下。
2.3.3 導出函數getExcel(res) { require.ensure([], () => { const { export_json_to_excel } = require("../../introduce/Export2Excel.js") const tHeader = ["姓名", "年齡"] const filterVal = ["name", "age"] const list = res const data = this.formatJson(filterVal, list) export_json_to_excel(tHeader, data, "導出列表名稱") }) }, formatJson(filterVal, jsonData) { return jsonData.map(v => filterVal.map(j => v[j])) },
這里的引用請根據自己的層級關系和文件夾命名require("../../introduce/Export2Excel.js")
res為傳入的數組,格式如:res =[{name:"小白",age:"18"},{name:"小黑",age:"16"}]
tHeader為導出Excel表頭名稱,導出列表名稱即為導出Excel名稱
下載的Excel位置根據瀏覽器設置的下載位置而定
3 后記感謝支持。若不足之處,歡迎大家指出,共勉。
如果覺得不錯,記得 點贊 ,謝謝大家
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/103871.html
摘要:使用時,前端可以將后端返回的數據拼接成自己需要導出的格式,下載到電腦中,完全不依賴后端。 前言 github: https://github.com/stardew516... 以往做excel表格下載功能的時候,都是后端生成好表格后,存儲在某個地方,然后給前端一個鏈接,前端使用a標簽加download下載,或者使用node。其實純前端也是可以做表格下載的,有一個很好用的javascr...
時間:2017年07月06日星期四說明:本文部分內容均來自慕課網。@慕課網:http://www.imooc.com教學源碼:無學習源碼:https://github.com/zccodere/s... 第一章:課程介紹 1-1 預備知識 基礎知識 struts2框架(上傳下載功能) xml解析技術(導入模板) JQuery EasyUI(前臺美觀) 課程目錄 實現方式 定制導入模版 導入文件 導...
摘要:四個參數分別是起始行終止行起始列終止列數據有效性對象包下載百度云盤外鏈 showImg(/img/bVqclu); xml文件 ...
1. 前言 本篇文章就是為大家講講前端導入并處理excel表格的情況,順便講講vue導入并處理excel數據;也總結下使用工具。 2.vue導入Excel表格 vue導入Excel表格主要有兩種常用的方法,一個是借助ElementUI文件上傳進行表格導入,另一個是自帶的input做文件上傳;以下對兩個方法做詳細介紹; 2.1 使用ElementUI中的upload組件 安裝Eleme...
摘要:有一個項目需求,要求在前端項目中導出表格,經過查找代碼確實可以實現,具體實現步驟為安裝依賴導入兩個下載和,在目錄下新建文件夾,里面放入和兩個文件在引入這兩個文件在組件中使用導出的方法序號昵稱姓名上面設置的表格第一行的標題上面的是里對 有一個項目需求,要求在前端項目中導出Excel表格,經過查找代碼,Vue.js確實可以實現,具體實現步驟為: 1.安裝依賴 npm install -S ...
閱讀 3317·2019-08-29 16:17
閱讀 1974·2019-08-29 15:31
閱讀 2644·2019-08-29 14:09
閱讀 2547·2019-08-26 13:52
閱讀 743·2019-08-26 12:21
閱讀 2125·2019-08-26 12:08
閱讀 991·2019-08-23 17:08
閱讀 1922·2019-08-23 16:59