Layui框架自带的导出excel数据默认导出的数据会以数字格式存放,比较长的数据存放后会经过科学计数法加工,从而导致数据错误 解决方法: 1、在/lib/layui-v2.5.5/lay/modules/table.js中搜索:d.exportFile 2、将d.e
Layui框架自带的导出excel数据默认导出的数据会以数字格式存放,比较长的数据存放后会经过科学计数法加工,从而导致数据错误

解决方法:
1、在/lib/layui-v2.5.5/lay/modules/table.js中搜索:d.exportFile
2、将d.exportFile这个函数,用下面内容替换掉:
d.exportFile = function (e, t, i) {
t = t || d.clearCacheKey(d.cache[e]), i = i || "csv";
var a = c.config[e] || {}, // 分页按钮
l = {csv: "text/csv", xls: "application/vnd.ms-excel"}[i], // meta格式
n = document.createElement("a"), // a 标签
type = i,
meta = l,
title = a.title
layui.each(t, function (ks, vs) {
var inner = {}
layui.each(vs, function (k, v) {
if (/^\d{9,}$/.test(v)) {
vs[k] = vs[k] + '\t'
}
inner[k] = vs[k]
});
t[ks] = inner
})
if (r.ie) {
var i = [], a = [];
layui.each(t, function (t, l) {
var n = [];
"object" == typeof e ? (layui.each(e, function (e, a) {
0 == t && i.push(a || "")
}), layui.each(d.clearCacheKey(l), function (e, t) {
n.push(t)
})) : d.eachCols(e, function (e, a) {
a.field && "normal" == a.type && !a.hide && (0 == t && i.push(a.title || ""), n.push(l[a.field]))
}), a.push(n.join(","))
});
var data = i.join(",") + "\r\n" + a.join("\r\n")
navigator.msSaveBlob(new Blob(['\ufeff' + data], {type: meta + ';charset=utf-8;'}), title + '.' + type)
} else {
return n.href = "data:" + l + ";charset=utf-8,\ufeff" + encodeURIComponent(function () {
var i = [], a = [];
return layui.each(t, function (t, l) {
var n = [];
"object" == typeof e ? (layui.each(e, function (e, a) {
0 == t && i.push(a || "")
}), layui.each(d.clearCacheKey(l), function (e, t) {
n.push(t)
})) : d.eachCols(e, function (e, a) {
a.field && "normal" == a.type && !a.hide && (0 == t && i.push(a.title || ""), n.push(l[a.field]))
}), a.push(n.join(","))
}), i.join(",") + "\r\n" + a.join("\r\n")
}()), n.download = (a.title || "table_" + (a.index || "")) + "." + i, document.body.appendChild(n), n.click(), void document.body.removeChild(n)}
},
编程基础网
本文标题为:解决layui框架excel导出长数据科学计数法问题
基础教程推荐
猜你喜欢
- Ajax实现关键字联想和自动补全功能及遇到坑 2023-02-23
- JavaScript开发简单易懂的Svelte实现原理详解 2023-08-12
- AJAX实现数据的增删改查操作详解【java后台】 2023-02-23
- 使用HTML5中postMessage知识点解决Ajax中POST跨域问题 2022-10-17
- 【vue】三种获取input值的写法 2023-10-08
- ajax异步加载图片实例分析 2022-12-18
- Ajax实现简单下拉选项效果【推荐】 2022-12-28
- vue在install时node-sass@4.14.1 postinstall:node scripts/build.js错误解决 2023-07-09
- html网页中使用希腊字母的方法 2022-09-21
- JavaScript函数this指向问题详解 2023-08-12
