vue讀取本地的excel檔案並顯示在網頁上
阿新 • • 發佈:2020-12-14
我想實現讀取一個本地的xlsx檔案(task_list.xlsx)然後顯示在網頁上, 一開始選擇的方法是建個express server, 通過傳送axios請求來實現, 但是覺得只是讀取一個本地檔案還要搞個server太複雜了, 最終還是通過"xlsx"模組 + axios實現了讀取本地檔案, 無需後端, 步驟如下:
1.通過vue-cli新建專案:
2.編寫分析excel workbook的指令碼
/src/scripts/read_xlsx.js
const XLSX = require('xlsx')
//將行,列轉換
function transformSheets(sheets) {
var content = []
var content1 = []
var tmplist = []
for (let key in sheets){
//讀出來的workbook資料很難讀,轉換為json格式,參考https://github.com/SheetJS/js-xlsx#utility-functions
tmplist.push(XLSX.utils.sheet_to_json(sheets[key]).length)
content1.push(XLSX.utils.sheet_to_json(sheets[key]))
}
var maxLength = Math.max.apply(Math, tmplist)
//進行行列轉換
for (let y in [...Array(maxLength)]){
content.push([])
for (let x in [...Array(tmplist.length)]) {
try {
for (let z in content1[x][y]){
content[y].push(content1[x][y][z])
}
} catch (error) {
content[y].push(' ')
}
}
}
content.unshift([])
for (let key in sheets){
content[0].push(key)
}
return content
}
export {transformSheets as default}
資源搜尋網站大全 https://www.renrenfan.com.cn 廣州VI設計公司https://www.houdianzi.com
3.新建一個元件
/src/components/task_list.vue
<template>
<div class="task-list">
<p v-if="err!==''">{{err}}</p> <!-- 用來顯示報錯 -->
<table style="margin:0 auto;" v-if="content!==''"> <!-- 設定居中,如果沒獲取到內容則不顯示 -->
<tr><th v-for="h in content[0]" :key="h.id">{{h}}</th></tr> <!-- 迴圈讀取資料 並顯示 -->
<tr v-for="row in content.slice(1,)" :key=row.id>
<td v-for="item in row" :key=item.id>{{item}}</td>
</tr>
</table>
</div>
</template>
<script>
import axios from 'axios'
import XLSX from 'xlsx'
import transformSheets from '../scripts/read_xlsx' //匯入轉制函式
export default {
name: 'TaskList',
data: function () {
return {
content: '', //初始化資料
err: ''
}
},
created() {
var url = "/task_list.xlsx" //放在public目錄下的檔案可以直接訪問
//讀取二進位制excel檔案,參考https://github.com/SheetJS/js-xlsx#utility-functions
axios.get(url, {responseType:'arraybuffer'})
.then((res) => {
var data = new Uint8Array(res.data)
var wb = XLSX.read(data, {type:"array"})
var sheets = wb.Sheets
this.content = transformSheets(sheets)
}).catch( err =>{
this.err = err
})
}
}
大功告成,編譯然後部署到伺服器吧
npmrun build
部署就不詳述了,把dist目錄丟到伺服器上就行.
效果就是這樣,程式設計新手,就這個東西斷斷續續搞了快一週了...