Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/jquery/71.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
使用javascript/jquery导出到excel后保留HTML表格样式_Jquery_Excel - Fatal编程技术网

使用javascript/jquery导出到excel后保留HTML表格样式

使用javascript/jquery导出到excel后保留HTML表格样式,jquery,excel,Jquery,Excel,我有一个漂亮的html表格从JSFIDLE,我会喜欢转换为excel文档。我的问题是在创建excel文件之后。表格将丢失excel中的样式,例如字体颜色、填充、背景色。等等,这有解决办法吗 HTML JAVASCRIPT var tableToExcel = (function() { var uri = 'data:application/vnd.ms-excel;base64,' , template = '<html xmlns:o="urn:schemas-micro

我有一个漂亮的html表格从JSFIDLE,我会喜欢转换为excel文档。我的问题是在创建excel文件之后。表格将丢失excel中的样式,例如字体颜色、填充、背景色。等等,这有解决办法吗

HTML

JAVASCRIPT

var tableToExcel = (function() {
  var uri = 'data:application/vnd.ms-excel;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]><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) { 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) {
    if (!table.nodeType) table = document.getElementById(table)
    var ctx = {worksheet: name || 'Worksheet', table: table.innerHTML}
    window.location.href = uri + base64(format(template, ctx))
  }
})()
var tableToExcel=(函数(){
var uri='data:application/vnd.ms excel;base64,'
,模板=“{table}”
,base64=函数{return window.btoa(unescape(encodeURIComponent))}
,format=函数(s,c){返回s.replace(/{(\w+)}/g,函数(m,p){返回c[p];})}
返回函数(表、名称){
如果(!table.nodeType)table=document.getElementById(table)
var ctx={工作表:名称| |'工作表',表:table.innerHTML}
window.location.href=uri+base64(格式(模板,ctx))
}
})()


我终于明白了。使用嵌入式或外部CSS样式将不起作用

观察
  • CSS必须是内联的
  • CSS必须位于表的
    th
    td
    元素上,因为它们表示Excel中的单元格
  • 颜色应该是十六进制
  • 总结
    从上面的代码中,我不需要外部CSS样式。我的所有CSS样式都需要内联到表中。

    可能与上述代码重复,以便导出。。如果你告诉我函数中的表和名称是什么,我不喜欢内联CSS,但看起来我不得不接受它。再次感谢您的输入。我无法调整excel中的列宽以匹配html表格中的列宽。我尝试了内联css,但无效。这是我的代码片段正常警告极端警告危险`我尝试过内联样式并在Excel 2016中打开它
    body
    {
        font-size: 12pt;
        font-family: Calibri;
        padding : 10px;
    }
    
    table
    {
        border: 1px solid black;
    
    }
    th
    {
        border: 1px solid black;
        padding: 5px;
        background-color:grey;
        color: white;
    
    }
    td
    {
        border: 1px solid black;
        padding: 5px;
    }
    
    input
    {
        font-size: 12pt;
        font-family: Calibri;
    }
    
    var tableToExcel = (function() {
      var uri = 'data:application/vnd.ms-excel;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]><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) { 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) {
        if (!table.nodeType) table = document.getElementById(table)
        var ctx = {worksheet: name || 'Worksheet', table: table.innerHTML}
        window.location.href = uri + base64(format(template, ctx))
      }
    })()