全部
常见问题
产品动态
精选推荐

xlsx-style的用法

管理 管理 编辑 删除
如何通过xlsx-style 修改导出excel的样式

f324f202304271744395461.png

实现导出的excel是带有边框的,满足打印的时候可以尽可能的铺满A4纸

安装 xlsx-style
npm install xlsx-style --save
修改xlsx-style 源码 解决报错
在\node_modules\xlsx-style\dist\cpexcel.js  
var cpt = require('./cpt' + 'able');  改为   var cpt = cptable; 
修改vue中的代码

完整代码

import XLSX from "xlsx";
import XLSXS from "xlsx-style";
import FileSaver from "file-saver";
export default {
  name: "excelDemo",
  methods: {
    toExcel() {
      let wb = XLSX.utils.table_to_book(this.$refs.table, { sheet: "分组表" });
      this.setExlStyle(wb["Sheets"]["分组表"]);
      this.addRangeBorder(
        wb["Sheets"]["分组表"]["!merges"],
        wb["Sheets"]["分组表"]
      );
      var ws = XLSXS.write(wb, {
        type: "buffer",
      });
      try {
        FileSaver.saveAs(
          new Blob([ws], { type: "application/octet-stream" }),
          `5.xlsx`
        );
      } catch (e) {
        if (typeof console !== "undefined") console.log(e, ws);
      }
      return ws;
    },
    setExlStyle(data) {
      let borderAll = {
        //单元格外侧框线
        top: {
          style: "thin",
        },
        bottom: {
          style: "thin",
        },
        left: {
          style: "thin",
        },
        right: {
          style: "thin",
        },
      };
      data["!cols"] = [];
      for (let key in data) {
        if (data[key] instanceof Object) {
          data[key].s = {
            border: borderAll,
            alignment: {
              horizontal: "center", //水平居中对齐
              vertical: "center",
            },
            font: {
              sz: 11,
            },
            bold: true,
            numFmt: 0,
          };
          data["!cols"].push({ wpx: 115 });
        }
      }
      return data;
    },
    addRangeBorder(range, ws) {
        // s:起始位置,e:结束位置
      let arr =["A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z"];
      range.forEach((item) => {
        let startRowNumber = Number(item.s.r), startColumnNumber = Number(item.s.c),endColumnNumber = Number(item.e.c),
          endRowNumber = Number(item.e.r);
        //   合并单元格时会丢失边框样式,例如A1->A4 此时内容在A1 而range内获取到的是从0开始的,所以开始行数要+2
        for (let i = startColumnNumber; i <= endColumnNumber; i++) {
            for(let j = startRowNumber+2 ;j<= endRowNumber+1 ; j++) {
                        console.log(arr[i] + j)
                          ws[arr[i] + j] = {
                            s: {
                            border: {
                                top: { style: "thin" },
                                left: { style: "thin" },
                                bottom: { style: "thin" },
                                right: { style: "thin" },
                            },
                            },
                        };
            }

        }
      });
      console.log(ws);
      return ws;
    },
  },
};


请登录后查看

CRMEB-慕白寒窗雪 最后编辑于2023-04-27 17:45:26

快捷回复
回复
回复
回复({{post_count}}) {{!is_user ? '我的回复' :'全部回复'}}
排序 默认正序 回复倒序 点赞倒序

{{item.user_info.nickname ? item.user_info.nickname : item.user_name}} LV.{{ item.user_info.bbs_level || item.bbs_level }}

作者 管理员 企业

{{item.floor}}# 同步到gitee 已同步到gitee {{item.is_suggest == 1? '取消推荐': '推荐'}}
{{item.is_suggest == 1? '取消推荐': '推荐'}}
沙发 板凳 地板 {{item.floor}}#
{{item.user_info.title || '暂无简介'}}
附件

{{itemf.name}}

{{item.created_at}}  {{item.ip_address}}
打赏
已打赏¥{{item.reward_price}}
{{item.like_count}}
{{item.showReply ? '取消回复' : '回复'}}
删除
回复
回复

{{itemc.user_info.nickname}}

{{itemc.user_name}}

回复 {{itemc.comment_user_info.nickname}}

附件

{{itemf.name}}

{{itemc.created_at}}
打赏
已打赏¥{{itemc.reward_price}}
{{itemc.like_count}}
{{itemc.showReply ? '取消回复' : '回复'}}
删除
回复
回复
查看更多
打赏
已打赏¥{{reward_price}}
948
{{like_count}}
{{collect_count}}
添加回复 ({{post_count}})

相关推荐

快速安全登录

使用微信扫码登录
{{item.label}} 加精
{{item.label}} {{item.label}} 板块推荐 常见问题 产品动态 精选推荐 首页头条 首页动态 首页推荐
取 消 确 定
回复
回复
问题:
问题自动获取的帖子内容,不准确时需要手动修改. [获取答案]
答案:
提交
bug 需求 取 消 确 定
打赏金额
当前余额:¥{{rewardUserInfo.reward_price}}
{{item.price}}元
请输入 0.1-{{reward_max_price}} 范围内的数值
打赏成功
¥{{price}}
完成 确认打赏

微信登录/注册

切换手机号登录

{{ bind_phone ? '绑定手机' : '手机登录'}}

{{codeText}}
切换微信登录/注册
暂不绑定
CRMEB客服

CRMEB咨询热线 咨询热线

400-8888-794

微信扫码咨询

CRMEB开源商城下载 源码下载 CRMEB帮助文档 帮助文档
返回顶部 返回顶部
CRMEB客服