国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Vue+Element前端導(dǎo)入導(dǎo)出Excel

NikoManiac / 1000人閱讀

摘要:前言業(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.jsExport2Excel.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

相關(guān)文章

  • 前端實(shí)現(xiàn)excel表格導(dǎo)入導(dǎo)出

    摘要:使用時(shí),前端可以將后端返回的數(shù)據(jù)拼接成自己需要導(dǎo)出的格式,下載到電腦中,完全不依賴后端。 前言 github: https://github.com/stardew516... 以往做excel表格下載功能的時(shí)候,都是后端生成好表格后,存儲(chǔ)在某個(gè)地方,然后給前端一個(gè)鏈接,前端使用a標(biāo)簽加download下載,或者使用node。其實(shí)純前端也是可以做表格下載的,有一個(gè)很好用的javascr...

    CoyPan 評(píng)論0 收藏0
  • 慕課網(wǎng)_《解密JAVA實(shí)現(xiàn)Excel導(dǎo)入導(dǎo)出》學(xué)習(xí)總結(jié)

    時(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)...

    enrecul101 評(píng)論0 收藏0
  • Java實(shí)現(xiàn)excel導(dǎo)入導(dǎo)出學(xué)習(xí)筆記2 - 利用xml技術(shù)設(shè)置導(dǎo)入模板,設(shè)置excel樣式

    摘要:四個(gè)參數(shù)分別是起始行終止行起始列終止列數(shù)據(jù)有效性對(duì)象包下載百度云盤外鏈 showImg(/img/bVqclu); xml文件 ...

    I_Am 評(píng)論0 收藏0
  • vue導(dǎo)入處理Excel表格功能步驟實(shí)例

      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...

    3403771864 評(píng)論0 收藏0
  • vue.js中如何導(dǎo)出Excel表格

    摘要:有一個(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 ...

    lunaticf 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<