jquery导出到excel表格以指数forms更改值

我有一个jQuery的导出表来优化代码。 但问题是,它改变的值是xls的导出文件。 我的表TD有一个值810101E001当我导出它改变了像8.10E + 06的值。

请给我解决scheme现在要做什么。

http://jsfiddle.net/wVejP/773/

jquery代码是

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)) } })() 

你不是真的把表格导出到Excel中,而是将它导出到Excel里面的HTML里面(例如,它仍然被编码为文件内的网页,当你保存/加载时会得到警告)。

在任何情况下,Excel都会将该字段解释为一个数字,为​​了阻止这样做,您必须设置该单元格的样式以指示它是文本。 但是,因为你没有将HTML翻译成内部的Excel XML语法,我不知道该怎么做(为什么它值得我相信这是正确的<Cell><ss:Data ss:Type="String" ...>...</Data></Cell> )。

因此,无论您需要将HTML完全转换为Excel XML,还是只需引用所有单元格数据,如下所示:

 contents = table.innerHTML .replace(/(<td[^>]*>)/gi, '$1"') .replace(/(<\/td[^>]*>)/gi, '"$1'); 

但是,这也引用了一切都不好,理想情况下,你想要某种方式来标记某些单元格作为文本,并引用他们 – 但如果你不能自动做到这一点,只要把引号放入HTML本身。 如果你知道单元格的位置,你可以通过引用单个单元格来实现(在你的例子中,这是第一个TD所以很简单)。

但是真的需要将HTML转换为Excel XML来正确地执行此操作(您仍然需要知道哪些单元不需要被解释为数字)。 看到这个答案的出发点: 将Excel电子表格转换为HTML