- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下代码:
<a id="dlink" style="display:none;"></a>
<input type="button" onclick="tableToExcel('cereriTable', 'Tabel Date', 'myfile.xls')" value="Export to Excel">
<script Language="javascript">
var tableToExcel = (function() {
var uri = 'data:application/vnd.ms-excel;charset=UTF-8;base64,'
, template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" ' +
'xmlns="http://www.w3.org/TR/REC-html40"><head>' +
'<!--[if gte mso 9]>' +
'<xsl:template name="styles">' +
'<style>' +
'table {' +
'mso-displayed-decimal-separator:"\,";' +
'mso-displayed-thousand-separator:" ";' +
'}' +
'@page {' +
'margin:.25in .25in .25in .25in;' +
'mso-header-margin:.15in;' +
'mso-footer-margin:.15in;' +
'mso-page-orientation:landscape;' +
'}' +
'tr {' +
'mso-height-source:auto;' +
'}' +
'col {' +
'mso-width-source:auto;' +
'}' +
'br {' +
'mso-data-placement:same-cell;' +
'}' +
'td {' +
'mso-style-parent:style0;' +
'padding-top:1px;' +
'padding-right:1px;' +
'padding-left:1px;' +
'mso-ignore:padding;' +
'color:windowtext;' +
'font-size:11.0pt;' +
'font-weight:300;' +
'font-style:normal;' +
'text-decoration:none;' +
'font-family:Calibri;' +
'mso-generic-font-family:auto;' +
'mso-font-charset:0;' +
'mso-number-format:General;' +
'text-align:general;' +
'vertical-align:bottom;' +
'border:none;' +
'mso-background-source:auto;' +
'mso-pattern:auto;' +
'mso-protection:locked visible;' +
'white-space:wrap;' +
'mso-rotate:0;' +
'}' +
'.longdate {' +
'mso-style-parent:style0;' +
'mso-number-format:"General Date";' +
'}' +
'.shortdate {' +
'mso-style-parent:style0;' +
'mso-font-charset:0;' +
'mso-number-format:"Short Date";' +
'white-space:normal;' +
'}' +
'.number {' +
'mso-style-parent:style0;' +
'mso-font-charset:0;' +
'mso-number-format:"0";' +
'white-space:normal;' +
'}' +
'.center {' +
'mso-style-parent:style0;' +
'font-weight:700;' +
'text-align:center;' +
'}' +
'.right {' +
'mso-style-parent:style0;' +
'text-align:right;' +
'}' +
'.header {' +
'mso-style-parent:style0;' +
'font-weight:700;' +
'}' +
'</style>' +
'<xml>' +
'<x:ExcelWorkbook>' +
'<x:ExcelWorksheets>' +
'<x:ExcelWorksheet>' +
'<x:Name>{worksheet}</x:Name>' +
'<x:WorksheetOptions>' +
'<x:DisplayGridlines/>' +
'</x:WorksheetOptions>' +
'</x:ExcelWorksheet>' +
'</x:ExcelWorksheets>' +
'</x:ExcelWorkbook>' +
'</xml>' +
'<![endif]-->' +
'</head>' +
'<body><table>{table}</table></body>' +
'</html>'
, base64 = function(s) {
while (s.indexOf('ş') != -1) s = s.replace('ş','s');
return window.btoa(unescape(encodeURIComponent(s)))
}
, format = function(s, c) {
return s.replace(/{(\w+)}/g, function(m, p) { return c[p]; })
}
return function(table, name, filename) {
if (!table.nodeType) table = document.getElementById(table)
var ctx = {worksheet: name || 'Worksheet', table: table.innerHTML}
document.getElementById("dlink").href = uri + base64(format(template, ctx));
document.getElementById("dlink").download = filename;
document.getElementById("dlink").click();
}
})();
</script>
我有一个数据表:
dataTable = $('#cereriTable').dataTable({...
我想要:
1) 从表中删除一列 - 在导出的 Excel 中(最后一列)
2)为每列设置单元格格式(文本/日期/数字),不通用...
3)mso-page-orientation:landscape 不起作用,我需要它......
4) 我在数据表中有多个页面,但这仅导出所选页面上的记录。
5)我想设置每列的宽度...(在导出的 Excel 中)
最佳答案
我是这样解决的:
<table id="cereriTable" style="text-align:center">
<thead>
<tr>
<th>Operator economic</th>
<th>Punct de lucru</th>
<th>Cod Fiscal</th>
<th>Judet</th>
<th>Data Introducere</th>
<th>Domeniu Acces</th>
<th>Tip cerere</th>
<th>Status</th>
<th>Username</th>
<th>Detalii</th>
</tr>
</thead>
<a id="dlink" style="display:none;"></a>
<input type="button" onclick="tableToExcel('cereriTable', 'Tabel Date', 'myfile.xls')"
title="If you are using Office 2007, please select 'Yes' from the resulting dialog."
value="Export to Excel">
<script Language="javascript">
var tableToExcel = (function() {
var uri = 'data:application/vnd.ms-excel;charset=UTF-8;base64,'
, template = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:x="urn:schemas-microsoft-com:office:excel" ' +
'xmlns="http://www.w3.org/TR/REC-html40"><head>' +
'<!--[if gte mso 9]>' +
'<xsl:template name="styles">' +
'<style>' +
'@page {' +
'margin:.25in .25in .25in .25in;' +
'mso-header-margin:.15in;' +
'mso-footer-margin:.15in;' +
'mso-page-orientation:landscape;' +
'}' +
'tr { mso-height-source:auto; }' +
'col { mso-width-source:auto; }' +
'br { mso-data-placement:same-cell; }' +
'td {' +
'mso-style-parent:style0;' +
'padding-top:1px;' +
'padding-right:1px;' +
'padding-left:1px;' +
'mso-ignore:padding;' +
'color:windowtext;' +
'font-size:11.0pt;' +
'font-weight:300;' +
'font-style:normal;' +
'text-decoration:none;' +
'font-family:Calibri;' +
'mso-generic-font-family:auto;' +
'mso-font-charset:0;' +
'mso-number-format:General;' +
'text-align:general;' +
'vertical-align:bottom;' +
'border:none;' +
'mso-background-source:auto;' +
'mso-pattern:auto;' +
'mso-protection:locked visible;' +
'white-space:wrap;' +
'mso-rotate:0;' +
'}' +
'.header {' +
'mso-style-parent:style0;' +
'font-weight:700;' +
'}' +
'.text {mso-number-format:"@";}' +
'.number {mso-number-format:"0";}' +
'.date {mso-number-format:"dd-mm-yyyy";text-align:left;}' +
'</style>' +
'<xml>' +
'<x:ExcelWorkbook><x:ExcelWorksheets><x:ExcelWorksheet>' +
'<x:Name>{worksheet}</x:Name>' +
'<x:WorksheetOptions><x:DisplayGridlines/></x:WorksheetOptions>' +
'</x:ExcelWorksheet></x:ExcelWorksheets></x:ExcelWorkbook>' +
'</xml>' +
'<![endif]-->' +
'</head>' +
'<body>' +
'<table>{table}</table>' +
'</body>' +
'</html>'
, base64 = function(s) {
while (s.indexOf('â') != -1) s = s.replace('â','a');
while (s.indexOf('ş') != -1) s = s.replace('ş','s');
while (s.indexOf('ă') != -1) s = s.replace('ă','a');
while (s.indexOf('ţ') != -1) s = s.replace('ţ','t');
return window.btoa(unescape(encodeURIComponent(s)))
}
, format = function(s, c) {
return s.replace(/{(\w+)}/g, function(m, p) { return c[p]; })
}
return function(table, name, filename) {
if (!table.nodeType) table = document.getElementById(table)
var output = '';
$("[id=cereriTable]").each(function(){
output += $(this).find("thead").html();//capul de tabel
$('#cereriTable tbody tr').each(function() {
var j=0;
output += '<tr class="">';
$.each(this.cells, function(){ //parcurg celulele de pe rand
j++;
if(j<10)//mai putin coloana de detalii
{
if(j==5)//coloana de data
output += '<td class="date">';
else if(j==3) //coloana de cod fiscal
output += '<td class="number">';
else//restul coloanelor sunt text
output += '<td class="text">';
output += $(this).html();
output += '</td>';
}
});
output += '</tr>';
});
});
var ctx = {worksheet: name || 'Worksheet', table: output}//table.innerHTML}
document.getElementById("dlink").href = uri + base64(format(template, ctx));
document.getElementById("dlink").download = filename;
document.getElementById("dlink").click();
}
})();
</script>
关于jquery - Javascript - 将 JQuery 数据表导出到 Excel 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17803261/
我有一个带有嵌套数据的 angular 数据表,我正在尝试在行点击函数上创建另一个数据表。父数据表的 rowCallBack 函数。 这是我的外部数据表 html; 这是我生成数据表的方
我有一个字母数字列,其中包含诸如“1、2、2”之类的字符串。 当我在搜索中输入“1, 2, 2”时,它似乎返回带有“1,”和“2,”的所有单元格。 我该怎么做才能使搜索仅返回“1、2、2”? 使用数据
我有一个获取其数据服务器端的表,使用自定义服务器端初始化参数,这些参数因生成的报告而异。表格生成后,用户可以打开一个弹出窗口,他们可以在其中添加多个附加过滤器以进行搜索。我需要能够使用与原始表相同的初
在 datatables我希望能够隐藏所有列,但似乎无法正确使用语法。 这来自下面的代码和上面的链接,创建了一个显示所有列的按钮。有没有办法写这个以便我可以隐藏所有列? {
我正在使用 DataTable 创建一个交互式表。我有 9 列,其中 5 列是值。我想根据它们的具体情况更改每个单元格的背景颜色。 我已经开始尝试首先更改整行颜色,因为这似乎是一项更容易的任务。但是我
我有一个简单的例子来说明我的问题。我正在使用数据表 1.9。当数据表位于另一个 html 表内时,水平滚动时列标题不会移动。当它不在 html 表中时它工作正常。我的示例实际上取自他们的水平滚动示例,
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
这是添加按钮以将数据导出到 csv、pdf、excel 的数据表示例...... fiddle here https://datatables.net/extensions/buttons/examp
是否有任何方法可以更改 angularjs 数据表中的按钮样式(colvis、copy、print、excel)。 vm.dtOptions = DTOptionsBuilder.newOptions
我试图弄清楚如何加入 2 个数据表并更新第一个但应用了过滤器。 DT DT2 b c 1: 1 10 2: 2 10 3: 3 10 4: 4 10 5: 5 10 6: 6 10 7: 7 10
我有一个数据表,其中包含许多包含值的列。我还有另一列,它定义了我需要选择哪些列的值。我很难找到一种方法来做到这一点。 这是一个简单的例子。 > d d value.1 value.2 name
我正在使用 data.table 包。我有一个数据表,表示用户在网站上的操作。假设每个用户都可以访问一个网站,并对其执行多项操作。我的原始数据表是 Action (每一行都是一个 Action ),我
我想知道每个变量在每个组中变化了多少次,然后将结果添加到所有组中。 我是这样找到的: mi[,lapply(.SD, function(x) sum(x != shift(x), na.rm=T)
有人可以向我解释一下如何向页眉或页脚添加按钮吗?Datatables 的开发者 Alan 说你必须离开网络服务器才能使用 Table Tools 来使用按钮。但我在独立计算机上离线运行 Datatab
我希望按 id 和按顺序(时间)计算不同的东西。 例如,与: dt = data.table( id=c(1,1,1,2,2,2,3,3,3), hour=c(1,5,5,6,7,8,23,23,23
我正在尝试在 JIRA 小工具中使用数据表,但在我的表准备就绪后,没有可用的分页按钮。我有一个表,我正在以最简单的方式使用数据表:$("#mytableid").dataTable(); 浏览页面元素
我有 responsive 表单中的数据表。 数据表生成 child rows在小型设备上。在这一行中,我有一些输入控件。这会导致两个问题。 第一个问题:**隐藏子行中的值不会进入表单数据。** 第二
我在使用 JQuery DataTable 捕获 keydown 事件时遇到问题。我的目标是允许用户使用箭头键导航表的行。因此,当用户按下箭头键时,我想捕获 keydown 事件并移动表的选定行(这是
是否有任何方法可以以编程方式更改显示的行数,而无需从下拉列表中手动选择? 我已经知道如何更改默认行数。当表首次加载时,我希望它加载所有行,然后“刷新”表以可能仅显示前 10 行。但我想以编程方式刷新表
我有一个数据表,我应该对其进行更改,例如我想更改内容的状态,但该内容位于表的第三页。当我更改它时,数据表会自行刷新到第一页。我想做的是保留选定的页码并在刷新后回调它。这可能吗? 顺便说一句,我正在使用
我是一名优秀的程序员,十分优秀!