增加 excel 导出的第一行标题选项 Former-commit-id: 66de20a3d02326759333a63a1f90e93834d7d420 [formerly 66de20a3d02326759333a63a1f90e93834d7d420 [formerly 66de20a3d02326759333a63a1f90e93834d7d420 [formerly 66de20a3d02326759333a63a1f90e93834d7d420 [formerly 3463e5feeaec05f84a8c42930edfbacaba6f0b92 [formerly 9ab91bc47458493d93f817aca80427749cb0acf6]]]]] Former-commit-id: 94df74e7c154789c835119fc23096fa6f8202ad5 Former-commit-id: 4a005fbd1ada5ce6e4cbb085b320660f2aa626cb Former-commit-id: 9d6dcc7b0e761e85a5295b235351b2e462c42f1f [formerly 607caf152de8bef7fede86a44e3003b1aaff2912] Former-commit-id: e54717456d4c5db124d9b8f0536a5dd6b1c9f8d7 Former-commit-id: 360f57cad825ce848e0cc1ef27835ec49837e0a8 Former-commit-id: 48de0f2794339a594d3fb37e3f76fdc6302932a9 Former-commit-id: e037bfa8bdb5e08b116cdea79887f82737b5034f Former-commit-id: e785e67cb2ee407b5b682bf8959767daff219ce7
74 lines
2.1 KiB
JavaScript
74 lines
2.1 KiB
JavaScript
/* eslint-disable */
|
|
|
|
// 库
|
|
import Csv from './_csv'
|
|
import ExportCsv from './_export-csv'
|
|
import FileSaver from 'file-saver'
|
|
import * as Excel from './_export2Excel'
|
|
|
|
export default {
|
|
install (Vue, options) {
|
|
Vue.prototype.$export = {
|
|
// 导出 csv
|
|
csv (params) {
|
|
return new Promise((resolve, reject) => {
|
|
// 默认值
|
|
const paramsDefault = {
|
|
columns: [],
|
|
data: [],
|
|
title: 'table',
|
|
noHeader: false
|
|
}
|
|
// 合并参数
|
|
const _params = Object.assign({}, paramsDefault, params)
|
|
// 生成数据
|
|
const data = Csv(_params.columns, _params.data, params, _params.noHeader)
|
|
// 下载数据
|
|
ExportCsv.download(_params.title, data)
|
|
// 完成
|
|
resolve()
|
|
})
|
|
},
|
|
// 导出 excel
|
|
excel (params) {
|
|
return new Promise((resolve, reject) => {
|
|
// 默认值
|
|
const paramsDefault = {
|
|
columns: [],
|
|
data: [],
|
|
title: 'table',
|
|
header: null,
|
|
merges: []
|
|
}
|
|
// 合并参数
|
|
const _params = Object.assign({}, paramsDefault, params)
|
|
// 从参数中派生数据
|
|
const header = _params.columns.map(e => e.label)
|
|
const data = _params.data.map(row => _params.columns.map(col => row[col.prop]))
|
|
// 导出
|
|
Excel.export_json_to_excel(header, data, _params.title, { merges: _params.merges, header: _params.header })
|
|
// 完成
|
|
resolve()
|
|
})
|
|
},
|
|
// 导出 文本文档
|
|
txt (params) {
|
|
return new Promise((resolve, reject) => {
|
|
// 默认值
|
|
const paramsDefault = {
|
|
text: '',
|
|
title: '文本'
|
|
}
|
|
// 合并参数
|
|
const _params = Object.assign({}, paramsDefault, params)
|
|
// 导出
|
|
const blob = new Blob([_params.text], {type: 'text/plain;charset=utf-8'})
|
|
FileSaver.saveAs(blob, _params.title + '.txt')
|
|
// 完成
|
|
resolve()
|
|
})
|
|
}
|
|
}
|
|
}
|
|
}
|