我目前正在研究jquery数据表。现在我正面临一个小问题,我想自定义导出的数据。即,我想自定义expoerted工作表。我成功地使用数据表页面https://datatables.net/extensions/buttons/examples/print/customisation.html
中的文档自定义打印按钮但无法自定义导出到excel / csv / pdf
以下代码是我当前的状态
buttons: [
{
extend: 'print',
exportOptions: {
columns: [1, 2, 3, 4, 6, 7, 13]
},
customize: function (win) {
$(win.document.body)
.css('font-size', '10pt')
.prepend(
'<img src="" style="position:absolute; top:0; left:0;" />'
);
$(win.document.body).find('table')
.addClass('compact')
.css('font-size', 'inherit');
},
},
{
extend: "collection",
text: "Save",
buttons: [
{
extend: 'csv',
exportOptions: {
columns: [1, 2, 3, 4, 6, 7, 13]
},
},
{
extend: 'excel',
exportOptions: {
columns: [1, 2, 3, 4, 6, 7, 13]
},
},
{
extend: 'pdf',
exportOptions: {
columns: [1, 2, 3, 4, 6, 7, 13]
},
customize: function (doc) {
doc.content.splice(1, 0, {
margin: [0, 0, 0, 12],
alignment: 'center',
image: ''
});
}
},
{
extend: 'copy',
exportOptions: {
columns: [1, 2, 3, 4, 6, 7, 13]
},
}
]
}
],
任何人都可以帮我实现这个
答案 0 :(得分:6)
对于excel,此函数将在文档顶部添加新行:
customize: function (xlsx) {
var sheet = xlsx.xl.worksheets['sheet1.xml'];
var numrows = 3;
var clR = $('row', sheet);
//update Row
clR.each(function () {
var attr = $(this).attr('r');
var ind = parseInt(attr);
ind = ind + numrows;
$(this).attr("r",ind);
});
// Create row before data
$('row c ', sheet).each(function () {
var attr = $(this).attr('r');
var pre = attr.substring(0, 1);
var ind = parseInt(attr.substring(1, attr.length));
ind = ind + numrows;
$(this).attr("r", pre + ind);
});
function Addrow(index,data) {
msg='<row r="'+index+'">'
for(i=0;i<data.length;i++){
var key=data[i].key;
var value=data[i].value;
msg += '<c t="inlineStr" r="' + key + index + '">';
msg += '<is>';
msg += '<t>'+value+'</t>';
msg+= '</is>';
msg+='</c>';
}
msg += '</row>';
return msg;
}
//insert
var r1 = Addrow(1, [{ key: 'A', value: '' }, { key: 'B', value: '' }]);
var r2 = Addrow(2, [{ key: 'A', value: '' }, { key: 'B', value: '' }]);
var r3 = Addrow(3, [{ key: 'A', value: '' }, { key: 'B', value: '' }]);
sheet.childNodes[0].childNodes[1].innerHTML = r1 + r2+ r3+ sheet.childNodes[0].childNodes[1].innerHTML;
}
对于CSV:
customize: function(doc){
return "Your text" + doc;
}
对于其他导出,您需要输入一个这样的消息参数:
{
extend: 'print',
message: "Your text"
},