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