在工作中,我們經常需要處理大量的Excel數據,而手動錄入十分耗時而且易出錯。幸運的是,現在有很多前端框架可以幫助我們快速實現Excel表格導入功能。其中,Vue框架以優秀的MVVM架構和數據雙向綁定等特性,受到了越來越多企業和開發者的青睞。下面就讓我們來介紹解釋一下,如何用Vue實現Excel表格導入吧!
首先,我們需要一個Excel表格上傳組件。可以使用一些現有的第三方組件庫,例如:element-ui or ant design 的 upload 組件。這邊以element-ui的 upload 組件為例子來講解。
選擇文件
在代碼里面我們使用了XLSX庫來實現Excel文件的讀取,首先在beforeUpload()方法中,我們進行對文件擴展名的判斷,判斷選擇的文件是否為 Excel 文件。其次讀取文件數據,使用 XLSX.read() 方法解析數據, Excel 文件又由多個 Sheet 組成,我們取第一個 Sheet,使用XLSX.utils.sheet_to_json() 方法將工作表轉化為 JSON 數據方便后續的業務處理。
接下來,我們需要將解析好的 Excel 數據渲染到表格,使用element-ui的表格組件即可,下面代碼以一個典型的例子來講解:
代碼中,通過 beforeUpload 方法中 this.$emit('on-excel-upload',excelJson.slice(1)) 將解析好的 Excel 數據發送到父組件的 handleExcelUpload() 方法中,通過雙層循環將數據賦值到數據源 tableData 上即可渲染出表格。
最后,在本例中,我們使用了 element-ui 及 XLSX 庫,讀者亦可自行選擇其他組件庫及對應 Excel 數據庫。請務必注意 Excel 數據中的空行或者數據類型,以保證程序的穩定性和彈性。