ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

xlsx-style 行高设置

2021-05-26 11:01:19  阅读:742  来源: 互联网

标签:xlsx style rows core js ws 行高


设置单元格高度

!rows,xlsx-style没有提供这个功能,但是xlsx有这个功能,所以解决这个问题方法有
(1)使用xlsx pro版本
(2)修改xlsx源码,给xlsx加上style功能
(3)修改xlsx-style源码,给xlsx加上 !rows功能
基于复杂程度和贫穷程度,选择(3)

步骤:
  1. 使用静态文件替代import
    (1)将node_modules里的xlsx-style的文件夹下的
    xlsx.core.min.js拿出来放在静态文件放置的文件夹下
    (2)index.html中引入
    <script src="<%= BASE_URL %>cdn/xlsx-style/xlsx.core.min.js" charset="utf-8"></script>

(3)删除import xlsxstyle代码

2.修改xlsx.core.min.js

位置:
write_ws_xml_data

 

 

 完整版代码如下:

https://files.cnblogs.com/files/yeminglong/xlsx.zip

function write_ws_xml_data(ws, opts, idx, wb) {
    var o = [],
      r = [],
      range = safe_decode_range(ws['!ref']),
      rowsHeight = ws['!rows'],
      cell,
      ref,
      rr = '',
      rh,
      cols = [],
      R, C
    for (C = range.s.c; C <= range.e.c; ++C) cols[C] = encode_col(C)
    for (R = range.s.r; R <= range.e.r; ++R) {
      r = []
      rr = encode_row(R)
      rh = -1
      hObj = rowsHeight[R]
      if (hObj && hObj.hpx) {
        rh = px2char(hObj.hpx)
      } else if (hObj && hObj.hch) {
        rh = hObj.hch
      }
      for (C = range.s.c; C <= range.e.c; ++C) {
        ref = cols[C] + rr
        if (ws[ref] === undefined) continue
        if ((cell = write_ws_xml_cell(ws[ref], ref, ws, opts, idx, wb)) != null) r.push(cell)
      }
      let p = {
        r: rr
      }
      if (rh > -1) {
        p.ht = char2height(rh)
        p.customHeight = 1
      }
      if (r.length > 0) o[o.length] = writextag('row', r.join(''), p)
    }
    return o.join('')
  }
function char2height(chr) { return 25; }

 

本文参考:https://www.cnblogs.com/coding-swallow/p/13433213.html

标签:xlsx,style,rows,core,js,ws,行高
来源: https://www.cnblogs.com/yeminglong/p/14812478.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有