Vue按钮导出Excel文件。
1、安装三个依赖
npm install -S file-saver xlsx
npm install -D script-loader
2、项目中新建一个文件夹:(vendor—名字任取)
里面放置两个文件Blob.js和 Export2Excel.js。
百度云:https://pan.baidu.com/s/1vJ7RnNMKYco2_8cfFbbfGg
提取码:y91k
3、调用方法
exportExcel() {
require.ensure([], () => {
const { export_json_to_excel } = require('../../vendor/Export2Excel')
const tHeader = ['订单号', '用户账号', '订单类型', '订单状态', '商品名称', '商品数量', '商品单价', '订单总额', '创建时间', '支付时间']
const filterVal = ['orderNo', 'userAccount', 'orderType', 'orderStatus', 'productName', 'productNum', 'productUnitPrice', 'orderPrice', 'orderSubmitTime', 'orderPayTime']
const list = res.data
const data = this.formatJson(filterVal, list)
export_json_to_excel(tHeader, data, '订单列表')
})
},
formatJson(filterVal, jsonData) {
return jsonData.map(v => filterVal.map(j => v[j]))
},
注:如果webpack报解析错误:
在build—-webpack.base.conf.js中resolve的alias加入 ‘vendor’: path.resolve(__dirname, ‘../src/vendor’),即可解决,alias是配置别名