代码拉取完成,页面将自动刷新
同步操作将从 没雨溪/项目管理系统前端v2.0 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
tableToExcel(titleList, dataSource)
function tableToExcel (titleList = [], dataSource = [], fileName = '') {
// 要导出的标题
// 处理数据 这样做是为了在很多数据的时候 导出自己想要的数据
const newDataSource = []
for (let i = 0; i < dataSource.length; i++) {
const tep = {}
titleList.forEach(({ key }) => { // key是colums中的每个key(name..age...)
tep[key] = dataSource[i][key]
})
newDataSource.push(tep)
}
let str = '<tr>'
for (let i = 0; i < titleList.length; i++) {
str += `<td>${titleList[i].title + '\t'}</td>`
}
str += '</tr>'
str += '<tr>'
for (let i = 0; i < newDataSource.length; i++) {
for (const item in newDataSource[i]) {
const news = newDataSource[i][item] ? newDataSource[i][item] : ''
// style="mso-number-format:\'@\'" =>excel科学计数
// \t制表符 tab到下一行
str += `<td style="mso-number-format:\'@\'">${news + '\t'}</td>`
}
str += '</tr>'
}
var linkName
var worksheet = linkName || 'sheet'// 下载之后excel下标显示名称(linkName是自己定义的名称)
var uri = 'data:application/vnd.ms-excel;base64,'
var 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><meta charset="UTF-8"><!--[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>${str}</table></body></html>`
var base64 = function (s) { return window.btoa(unescape(encodeURIComponent(s))) }
var link = document.createElement('a')
link.href = uri + base64(template)
link.download = linkName || '数据.xls'// 当前下载的excel名称
document.body.appendChild(link)
link.innerHTML = '点击下载'
console.log(unescape(encodeURIComponent(template)))
link.click()
document.body.removeChild(link)
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。