当前位置: 首页 > wzjs >正文

网站备案和服务器备案吗dedeai网站最新

网站备案和服务器备案吗,dedeai网站最新,广告联盟赚钱平台,wordpress实现html5预加载Vue2中 前端界面导出表格,使用XLSXS插件版本(^0.8.13)导出表格存在表格背景颜色无法正常展示,百分比数据没有正常展示 【有条件的尽量先升级高版本插件,此插件版本对样式支持度不够】 优先考虑插件版本升级 同样的使用方法在vue3中没有出现错…

        Vue2中 前端界面导出表格,使用XLSXS插件版本(^0.8.13)导出表格存在表格背景颜色无法正常展示,百分比数据没有正常展示 【有条件的尽量先升级高版本插件,此插件版本对样式支持度不够

        优先考虑插件版本升级 同样的使用方法在vue3中没有出现错误

    以下为界面上表格,表格采用vxe-table组件  整个表格的列均为动态计算得出

导出后的表格样式丢失 且最后一行数据百分比不能正常展示

以下为封装的批量倒出代码 使用需根据项目自行更改

import FileSaver from 'file-saver'
import XLSXS from 'xlsx-style'export function exportMultiSheetExcel(tables, // [{ el: tableDom, name: 'Sheet1' }, ...]{fileName = '多Sheet表格',style,colWidth,callback,  // 回调 对数据进行处理addCell,DataManipulationMethod}
) {const wb = XLSX.utils.book_new();tables.forEach(({ el, name, index }) => {const sheet = XLSX.utils.table_to_sheet(el);if (colWidth) sheet['!cols'] = colWidth;DataManipulationMethod && DataManipulationMethod(sheet, index);Object.keys(sheet).forEach((key) => {if (key.startsWith('!')) return;const cell = sheet[key];if (!cell || cell.v === '' || cell.v == null) return;cell.s = style || {};callback && callback(key, cell, sheet);});addCell && addCell(sheet);XLSX.utils.book_append_sheet(wb, sheet, name || 'Sheet');});const wbout = XLSXS.write(wb, {bookType: 'xlsx',type: 'binary',cellStyles: true})// 创建 Blob 并下载const blob = new Blob([s2ab(wbout)], {type: 'application/octet-stream'});const url = window.URL.createObjectURL(blob);const a = document.createElement('a');a.href = url;a.download = `${name || '表格'}.xlsx`;a.click();window.URL.revokeObjectURL(url);
}// 表格使用 ----------
import { exportMultiSheetExcel } from '@/utils'exportTable(){this.tableScheme.forEach((tableEle, index) => {// let ws = this.tableColumnHandle(tableEle.columns, this.$refs['scheme' + index][0])tables.push({el: this.$refs['scheme' + index][0].$el,// name: tableEle?.columns[0]?.title.replace(/\d{4}年/g, '').replace(/\d{2}月/g, '').replace(/:/g, '-').replace(/方案/g, ''),name: '123' + index,  // sheet的名称 注意名称不能超过31个字符且不能包含:等字符index})})exportMultiSheetExcel(// 导出用隐藏的导出格式表格tables,{fileName: '方案',style: {alignment: {horizontal: 'center', // 水平居中对齐vertical: 'center',wrapText: true}},callback: (key, item, obj) => {if (key === 'B5') {console.log(key)item.s = {alignment: {horizontal: 'center', // 水平居中对齐vertical: 'center',wrapText: true},fill: {fgColor: { rgb: 'FFb0e1' }}}}},DataManipulationMethod: (data, index) => {console.log(data, 'dd')const fixedCode = ['A', 'B']const tableDataLength = this.tableScheme[index].data.length // 表格数据行数const headNum = 3 // 表头占用行数const endNum = 2 // 表尾占用行数const keysArr = []// 非A 或者 B 开始的数据 需要删除 表尾后的多余固定列脏数据 即  tableDataLength+headNum+endNum 之后的let maxNum = 0for (const key in data) {if (!key.includes('!')) {const num = key.replace(/[A-Za-z]/g, '') - 0if (num > maxNum) maxNum = numconst code = key.replace(/[0-9]/g, '')if (!keysArr.includes(code)) keysArr.push(code)if (fixedCode.includes(code) && headNum + 1 <= num && num <= tableDataLength + headNum) {if (data[key].v === '') {// 固定列替换成有数据的data[key] = data[key.replace(/[0-9]/g, '') + (num + tableDataLength + headNum + endNum)]}}}}// 删除固定列脏数据keysArr.forEach(code => {for (let num = (tableDataLength + headNum + endNum + 1); num <= maxNum; num++) {delete data[`${code + num}`]}})}})
}

插件使用过程中踩坑:

1,导出sheet名称不符规范

       导出多个表格到同一个excel表格中的代码参考如下

this.tableScheme.forEach((tableEle, index) => { let ws = this.tableColumnHandle(tableEle.columns, this.$refs['scheme' + index][0])  /// 表格部分数据处理wsArr.push({title: tableEle?.columns[0]?.title, ws: ws})})const wb = XLSX.utils.book_new();wsArr.forEach( item => { // excel表格 sheet名称不能包含 :号 31个字符内const sheetName = item.title.replace(/\d{4}年/g, '').replace(/\d{2}月/g, '').replace(/:/g, '-').replace(/方案/g, '')XLSX.utils.book_append_sheet(wb, item.ws, sheetName);  // 此处添加到对应的sheet中})XLSX.writeFile(wb, '调时方案执行情况.xlsx');

excel中的sheet名称要求如下:

style: {alignment: {horizontal: 'center', // 水平居中对齐vertical: 'center',wrapText: true},fill: {fgColor: { rgb: 'FFD6D6' } // 例如红色背景}
},

2,表格背景色不展示

如果设置全局的颜色 可以显示  但是对单个背景色进行设置就不显示了

全局直接在style中添加即可

style: {alignment: {horizontal: 'center', // 水平居中对齐vertical: 'center',wrapText: true},fill: {fgColor: { rgb: 'FFD6D6' } // 例如红色背景}
},

对单个背景色进行处理 在回调callback中进行条件判断  注意 必须整个item.s 一起写 包括剧中 否则就不生效

callback: (key, item, obj) => {            if (key === 'B5') {item.s = {alignment: {horizontal: 'center', // 水平居中对齐vertical: 'center',wrapText: true},fill: {fgColor: { rgb: 'FFb0e1' }}}}
},

3,百分比格式设置之后不生效

正常情况只需要在回调callback中 或者 DataManipulationMethod 处理方法中对数据进行格式命名numFmt  即可

data[key].s = {alignment: { horizontal: 'center', vertical: 'center', wrapText: true },numFmt: '0.00%'  // 只设置格式
}

不生效在用以下方法 直接改为string格式

const percent = data[key].v * 100;data[key].v = Number.isInteger(percent)? `${percent}%`: `${percent.toFixed(2)}%`;data[key].t = 's'; // 明确设为字符串,防止 Excel 报错

文章转载自:

http://KengJvRn.rhchr.cn
http://Z9Gmgldh.rhchr.cn
http://mNP2pKUL.rhchr.cn
http://XzpYFLAj.rhchr.cn
http://gTLaGHzO.rhchr.cn
http://756s8msb.rhchr.cn
http://Yi0zrrgQ.rhchr.cn
http://qoHRAXi4.rhchr.cn
http://8Ln6QjTQ.rhchr.cn
http://m731JqtB.rhchr.cn
http://rULEVInG.rhchr.cn
http://hAxSV1PR.rhchr.cn
http://q80iXH2d.rhchr.cn
http://4MZcSrZ0.rhchr.cn
http://EhnpJcoa.rhchr.cn
http://N5ZI5UB8.rhchr.cn
http://BgNRws1c.rhchr.cn
http://bkgR3nEu.rhchr.cn
http://C7gzuKPf.rhchr.cn
http://fWC4mAGY.rhchr.cn
http://EU5vUpXQ.rhchr.cn
http://YYnmIAXC.rhchr.cn
http://dM0pHeX0.rhchr.cn
http://sRsNE1PE.rhchr.cn
http://H0d0RFW4.rhchr.cn
http://xChIYpSl.rhchr.cn
http://5Vd5qfCn.rhchr.cn
http://nNYPisyc.rhchr.cn
http://QuaGTTAR.rhchr.cn
http://KijWwRUN.rhchr.cn
http://www.dtcms.com/wzjs/630141.html

相关文章:

  • 俄语网站里做外贸shop淮北网站开发公司
  • 网站优化推广seowordpress 火车采集
  • 网站开发工具的功能app开发比较好的公司
  • 一级域名 二级域名 目录网站推广网站推广工具有啥
  • 443是端口网站建设哪个小说网站版权做的好
  • wordpress手机同步湛江网站关键字优化
  • 有经验的手机网站建设网站优化策划方案
  • 网站宣传方案北京网站设计公司cg成都柚米科技15
  • 做网站用户充值提现seo教程论坛
  • 做网站网站需要多少钱做30个精品网站
  • 网站开发基本流程网站建设.c
  • 网站建设分析方法怎么做网站访问量
  • 搭建平台有哪些平台说法西安seo霸屏
  • 网站开发所要达到的目标网站建建设
  • 网站注册免费qq网站建设junke100
  • 北京做网站比较好的公司wordpress 换空间
  • 网站开发工具 哪个好淳安千岛湖建设集团网站
  • 网站建设相关的书籍视频网站的做
  • 卢松松网站的百度广告怎么做的点墨网站
  • 网站建设get你编辑html
  • 雕塑网站模板typecho导入wordpress
  • 大型网站建设视频坚持以高质量发展为首要任务一
  • 阿里云做网站麻烦吗织梦转wordpress
  • 做网站经营流量wordpress随机评论头像
  • 《网站开发实训》实验报告WordPress部署商城
  • dedecms 企业网站前端个人网站模板
  • 好大夫官方网站网上预约挂号网站开发税收标准
  • 企业网站推广文案哪个网站做员工增员
  • 深圳 企业 网站建设哪家好网站标题用什么符号分开
  • 重庆网站推广优化维护官网内容是什么工作