增加 excel 导出的合并单元格选项
增加 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
This commit is contained in:
@@ -50,7 +50,9 @@ export default {
|
|||||||
exportExcel () {
|
exportExcel () {
|
||||||
this.$export.excel({
|
this.$export.excel({
|
||||||
columns: this.table.columns,
|
columns: this.table.columns,
|
||||||
data: this.table.data
|
data: this.table.data,
|
||||||
|
header: '导出 Excel',
|
||||||
|
merges: ['A1', 'E1']
|
||||||
})
|
})
|
||||||
.then(() => {
|
.then(() => {
|
||||||
this.$message('导出表格成功')
|
this.$message('导出表格成功')
|
||||||
|
|||||||
@@ -124,16 +124,22 @@ export function export_table_to_excel(id) {
|
|||||||
function formatJson(jsonData) {
|
function formatJson(jsonData) {
|
||||||
console.log(jsonData)
|
console.log(jsonData)
|
||||||
}
|
}
|
||||||
export function export_json_to_excel(th, jsonData, defaultTitle) {
|
export function export_json_to_excel(th, jsonData, defaultTitle, options = { merges: [], header: null }) {
|
||||||
|
|
||||||
/* original data */
|
/* original data */
|
||||||
|
|
||||||
var data = jsonData;
|
var data = jsonData;
|
||||||
data.unshift(th);
|
data.unshift(th);
|
||||||
|
if (options.header) data.unshift([options.header]);
|
||||||
var ws_name = "SheetJS";
|
var ws_name = "SheetJS";
|
||||||
|
|
||||||
var wb = new Workbook(), ws = sheet_from_array_of_arrays(data);
|
var wb = new Workbook(), ws = sheet_from_array_of_arrays(data);
|
||||||
|
|
||||||
|
/* add merges area to worksheet */
|
||||||
|
let { merges } = options;
|
||||||
|
if (typeof merges[0] == 'string' && merges.length == 2) merges = [merges] // just one # ['A1', 'C1'] = > [['A1', 'C1']]
|
||||||
|
merges = merges.map(i => i instanceof Array ? { s: i[0], e: i[1] } : i); // be sort :) # ['A1', 'C1'] => { s: 'A1', e: 'C3' }
|
||||||
|
ws['!merges'] = merges;
|
||||||
|
|
||||||
/* add worksheet to workbook */
|
/* add worksheet to workbook */
|
||||||
wb.SheetNames.push(ws_name);
|
wb.SheetNames.push(ws_name);
|
||||||
|
|||||||
@@ -36,7 +36,9 @@ export default {
|
|||||||
const paramsDefault = {
|
const paramsDefault = {
|
||||||
columns: [],
|
columns: [],
|
||||||
data: [],
|
data: [],
|
||||||
title: 'table'
|
title: 'table',
|
||||||
|
header: null,
|
||||||
|
merges: []
|
||||||
}
|
}
|
||||||
// 合并参数
|
// 合并参数
|
||||||
const _params = Object.assign({}, paramsDefault, params)
|
const _params = Object.assign({}, paramsDefault, params)
|
||||||
@@ -44,7 +46,7 @@ export default {
|
|||||||
const header = _params.columns.map(e => e.label)
|
const header = _params.columns.map(e => e.label)
|
||||||
const data = _params.data.map(row => _params.columns.map(col => row[col.prop]))
|
const data = _params.data.map(row => _params.columns.map(col => row[col.prop]))
|
||||||
// 导出
|
// 导出
|
||||||
Excel.export_json_to_excel(header, data, _params.title)
|
Excel.export_json_to_excel(header, data, _params.title, { merges: _params.merges, header: _params.header })
|
||||||
// 完成
|
// 完成
|
||||||
resolve()
|
resolve()
|
||||||
})
|
})
|
||||||
|
|||||||
Reference in New Issue
Block a user