摘要:前言業(yè)務(wù)場景由前臺導(dǎo)入表格,獲取批量數(shù)據(jù)。根據(jù)一個數(shù)組導(dǎo)出表格。每一個值是個對象,包含了兩個屬性。由于本人將和放到了同一級,這里引入是這樣的。這幾個文件不支持引入,所以需要來將他們掛載到全局環(huán)境下。若不足之處,歡迎大家指出,共勉。
1 前言 1.1 業(yè)務(wù)場景
由前臺導(dǎo)入Excel表格,獲取批量數(shù)據(jù)。
根據(jù)一個數(shù)組導(dǎo)出Excel表格。
2 實現(xiàn)原理 2.1 引入工具庫file-saver、xlsx、script-loader
npm install -S file-saver xlsx
npm install -D script-loader
2.2 導(dǎo)入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。
這里發(fā)現(xiàn)控件file.raw是我們要用的File類型。
2.2.2 導(dǎo)入判斷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 導(dǎo)入函數(shù)
importfxx(obj) { let _this = this; // 通過DOM取文件數(shù)據(jù) 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; //讀取完成的數(shù)據(jù) 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)), { //手動轉(zhuǎn)化 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["設(shè)備ID"] obj.type = v["設(shè)備型號"] arr.push(obj) }) return arr } reader.readAsArrayBuffer(f); } if(rABS) { reader.readAsArrayBuffer(f); } else { reader.readAsBinaryString(f); } },
arr就是我們要的結(jié)果,是一個數(shù)組。每一個值是個對象,包含了code type兩個屬性。
excel中格式為橫向 設(shè)備ID 和 設(shè)備型號。
2.3 導(dǎo)出Excel 2.3.1 引入JS文件可參考下載地址:- github
將其中的2個JS文件放入到自己的工程中。
2.3.2 修改JS文件中地址
打開Export2Excel.js,會出現(xiàn)如上圖所示。由于本人將Blob.js和Export2Excel.js放到了同一級,這里引入是這樣的。
這幾個文件不支持import引入,所以需要script-loader來將他們掛載到全局環(huán)境下。
2.3.3 導(dǎo)出函數(shù)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, "導(dǎo)出列表名稱") }) }, formatJson(filterVal, jsonData) { return jsonData.map(v => filterVal.map(j => v[j])) },
這里的引用請根據(jù)自己的層級關(guān)系和文件夾命名require("../../introduce/Export2Excel.js")
res為傳入的數(shù)組,格式如:res =[{name:"小白",age:"18"},{name:"小黑",age:"16"}]
tHeader為導(dǎo)出Excel表頭名稱,導(dǎo)出列表名稱即為導(dǎo)出Excel名稱
下載的Excel位置根據(jù)瀏覽器設(shè)置的下載位置而定
3 后記感謝支持。若不足之處,歡迎大家指出,共勉。
如果覺得不錯,記得 點贊 ,謝謝大家
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://www.ezyhdfw.cn/yun/103871.html
摘要:使用時,前端可以將后端返回的數(shù)據(jù)拼接成自己需要導(dǎo)出的格式,下載到電腦中,完全不依賴后端。 前言 github: https://github.com/stardew516... 以往做excel表格下載功能的時候,都是后端生成好表格后,存儲在某個地方,然后給前端一個鏈接,前端使用a標(biāo)簽加download下載,或者使用node。其實純前端也是可以做表格下載的,有一個很好用的javascr...
時間:2017年07月06日星期四說明:本文部分內(nèi)容均來自慕課網(wǎng)。@慕課網(wǎng):http://www.imooc.com教學(xué)源碼:無學(xué)習(xí)源碼:https://github.com/zccodere/s... 第一章:課程介紹 1-1 預(yù)備知識 基礎(chǔ)知識 struts2框架(上傳下載功能) xml解析技術(shù)(導(dǎo)入模板) JQuery EasyUI(前臺美觀) 課程目錄 實現(xiàn)方式 定制導(dǎo)入模版 導(dǎo)入文件 導(dǎo)...
摘要:四個參數(shù)分別是起始行終止行起始列終止列數(shù)據(jù)有效性對象包下載百度云盤外鏈 showImg(/img/bVqclu); xml文件 ...
1. 前言 本篇文章就是為大家講講前端導(dǎo)入并處理excel表格的情況,順便講講vue導(dǎo)入并處理excel數(shù)據(jù);也總結(jié)下使用工具?! ?.vue導(dǎo)入Excel表格 vue導(dǎo)入Excel表格主要有兩種常用的方法,一個是借助ElementUI文件上傳進行表格導(dǎo)入,另一個是自帶的input做文件上傳;以下對兩個方法做詳細介紹; 2.1 使用ElementUI中的upload組件 安裝Eleme...
摘要:有一個項目需求,要求在前端項目中導(dǎo)出表格,經(jīng)過查找代碼確實可以實現(xiàn),具體實現(xiàn)步驟為安裝依賴導(dǎo)入兩個下載和,在目錄下新建文件夾,里面放入和兩個文件在引入這兩個文件在組件中使用導(dǎo)出的方法序號昵稱姓名上面設(shè)置的表格第一行的標(biāo)題上面的是里對 有一個項目需求,要求在前端項目中導(dǎo)出Excel表格,經(jīng)過查找代碼,Vue.js確實可以實現(xiàn),具體實現(xiàn)步驟為: 1.安裝依賴 npm install -S ...
閱讀 3426·2019-08-29 16:17
閱讀 2039·2019-08-29 15:31
閱讀 2729·2019-08-29 14:09
閱讀 2627·2019-08-26 13:52
閱讀 815·2019-08-26 12:21
閱讀 2207·2019-08-26 12:08
閱讀 1096·2019-08-23 17:08
閱讀 2098·2019-08-23 16:59