有一個項目需求,要求在前端項目中導出Excel表格,通過查找代碼,Vue.js確實能夠實現,具體實現步驟爲:前端
1.安裝依賴npm
npm install -S file-saver xlsx npm install -D script-loader
2.導入兩個JS
下載Blob.js和Export2Excel.js,在src目錄下新建Excel文件夾,裏面放入Blob.js和Export2Excel.js兩個JS文件json
3.在main.js引入這兩個JS文件 **api
import Blob from './excel/Blob' import Export2Excel from './excel/Export2Excel.js'
4.在組件中使用數組
//導出的方法 exportExcel() { require.ensure([], () => { const { export_json_to_excel } = require('../excel/Export2Excel'); const tHeader = ['序號', '暱稱', '姓名']; // 上面設置Excel的表格第一行的標題 const filterVal = ['index', 'nickName', 'name']; // 上面的index、nickName、name是tableData裏對象的屬性 const list = this.tableData; //把data裏的tableData存到list const data = this.formatJson(filterVal, list); export_json_to_excel(tHeader, data, '列表excel'); }) }, formatJson(filterVal, jsonData) { return jsonData.map(v => filterVal.map(j => v[j])) }
tHeader是表頭,filterVal 中的數據是表格的字段,tableData中存放表格裏的數據,類型爲數組,裏面存放對象,表格的每一行爲一個對象。
tableData 中的值爲:post
data () { return { tableData: [ {'index':'0',"nickName": "沙灘擱淺咱們的舊時光", "name": "小明"}, {'index':'1',"nickName": "女人天生高貴", "name": "小紅"}, {'index':'2',"nickName": "海是彩色的灰塵", "name": "小蘭"} ] }
}ui
最後實現的效果圖:
this
若是運行時,報以下所示的錯誤:spa
這是由於Export2Excel.js的設置須要改下:
excel
注: 把require('script-loader!vendor/Blob')改成 require('./Blob.js')
項目中實際應用案例
/導出 */
formatJson(filterVal, jsonData) { // console.log(filterVal,jsonData) return jsonData.map(v => filterVal.map(j => { if(j == 'xxdz'){ //..詳細地址 return v.name1 + v.name2 + v.name3 + v.gridName + v.xxdz } if(j == 'qyzw'){ //..區域裝維 return v.name2 + '/' + v.yxCname } if(j == 'state'){ //..工單狀態 return this.config.gzdStateList[v.state] } return v[j] })) }, ygExcel() { let params = {} let queryForm = this.deepClone(this.queryForm) params.currentPage =1 params.pageSize = this.count params.queryForm = queryForm params.prop = this.prop params.order = this.order // params.ifExport = true this.startLoading() this.$post( "/api/UserController/getList",params, (data) => { console.log(data) let tableData =data.list; // let tableData = data.list; require.ensure([], () => { const { export_json_to_excel } = require('../vendor/Export2Excel'); const tHeader = this.config.ygbHeader;//在config中定義表頭 const filterVal = this.config.ygFilterVal;//在config中定義表頭對應的字段 const data = this.formatJson(filterVal, tableData); export_json_to_excel(tHeader, data, '員工詳情表');下載是顯示的表名 }) }) },