exceljs 增加边框设置inside、outside的导出+金额大写导出

直接上代码:里面还有引用了个js文件 下面附加

import ExcelJS from 'exceljs';

import { useI18n } from '/@/hooks/web/useI18n';//可删,私有方法

import FileSaver from 'file-saver';

import { useMessage } from '/@/hooks/web/useMessage';

import { createCellRange, setConditions, setDataValidation } from './utils';

const { createMessage } = useMessage();//可删,私有方法

const { t } = useI18n();//可删,私有方法



function exportExcel(luckysheet, name, excelType = 'wps') {

  // 1.创建工作簿,可以为工作簿添加属性

  const workbook = new ExcelJS.Workbook();

  // 2.创建表格,第二个参数可以配置创建什么样的工作表

  luckysheet.forEach(function (table) {

    // debugger

    if (table.data.length === 0) return true;

    const worksheet = workbook.addWorksheet(table.name);

    const merge = (table.config && table.config.merge) || {}; //合并单元格

    const borderInfo = (table.config && table.config.borderInfo) || {}; //边框

    const columnWidth = (table.config && table.config.columnlen) || {}; //列宽

    const rowHeight = (table.config && table.config.rowlen) || {}; //行高

    const frozen = table.frozen || {}; //冻结

    const rowhidden = (table.config && table.config.rowhidden) || {}; //行隐藏

    const colhidden = (table.config && table.config.colhidden) || {}; //列隐藏

    const filterSelect = table.filter_select || {}; //筛选

    const images = table.images || {}; //图片

    // console.log(table)

    const hide = table.hide; //工作表 sheet 1隐藏

    if (hide === 1) {

      // 隐藏工作表

      worksheet.state = 'hidden';

    }

    setStyleAndValue(table.data, worksheet);

    setMerge(merge, worksheet);

    setBorder(borderInfo, worksheet);

    setImages(images, worksheet, workbook);

    setColumnWidth(columnWidth, worksheet);

    //行高设置50导出后在ms-excel中打开显示25,在wps-excel中打开显示50这个bug不会修复

    setRowHeight(rowHeight, worksheet, excelType);

    setFrozen(frozen, worksheet);

    setRowHidden(rowhidden, worksheet);

    setColHidden(colhidden, worksheet);

    setFilter(filterSelect, worksheet);

    setConditions(table.luckysheet_conditionformat_save, worksheet);

    setDataValidation(table.dataVerification, worksheet);

    return true;

  });



  // 4.写入 buffer

  const buffer = workbook.xlsx.writeBuffer().then((data) => {

    const blob = new Blob([data], {

      type: 'application/vnd.ms-excel;charset=utf-8',

    });

    createMessage.success(t('report.output.excel.loading'));

    saveAs(blob, `${name}.xlsx`);

  });

  return buffer;

}



/**

 * 列宽

 * @param columnWidth

 * @param worksheet

 */

var setColumnWidth = function (columnWidth, worksheet) {

  for (let key in columnWidth) {

    worksheet.getColumn(parseInt(key) + 1).width = columnWidth[key] / 7.5;

  }

};



/**

 * 行高

 * @param rowHeight

 * @param worksheet

 * @param excelType

 */

var setRowHeight = function (rowHeight, worksheet, excelType) {

  //导出的文件用wps打开和用excel打开显示的行高大一倍

  if (excelType == 'wps') {

    for (let key in rowHeight) {

      worksheet.getRow(parseInt(key) + 1).height = rowHeight[key] * 0.75;

    }

  }

  if (excelType == 'office' || excelType == undefined) {

    for (let key in rowHeight) {

      worksheet.getRow(parseInt(key) + 1).height = rowHeight[key] * 1.5;

    }

  }

};



/**

 * 合并单元格

 * @param luckyMerge

 * @param worksheet

 */

var setMerge = function (luckyMerge = {}, worksheet) {

  const mergearr = Object.values(luckyMerge);

  mergearr.forEach(function (elem) {

    // elem格式:{r: 0, c: 0, rs: 1, cs: 2}

    // 按开始行,开始列,结束行,结束列合并(相当于 K10:M12)

    worksheet.mergeCells(elem.r + 1, elem.c + 1, elem.r + elem.rs, elem.c + elem.cs);

  });

};



/**

 * 设置边框

 * @param luckyBorderInfo

 * @param worksheet

 */

var setBorder = function (luckyBorderInfo, worksheet) {

  if (!Array.isArray(luckyBorderInfo)) return;



  //合并边框信息

  var mergeCellBorder = function (border1, border2) {

    if (undefined === border1 || Object.keys(border1).length === 0) return border2;

    return Object.assign({}, border1, border2);

  };



  // console.log('luckyBorderInfo', luckyBorderInfo)

  luckyBorderInfo.forEach(function (elem) {

    // 现在只兼容到borderType 为range的情况

    // console.log('ele', elem)

    if (elem.rangeType === 'range') {

      let border = borderConvert(elem.borderType, elem.style, elem.color);

      let rang = elem.range[0];

      let row = rang.row;

      let column = rang.column;



      let rowBegin = row[0];

      let rowEnd = row[1];

      let colBegin = column[0];

      let colEnd = column[1];

      //处理外边框的情况 没有直接对应的外边框 需要转换成上下左右

      if (border.all) {

        //全部边框

        let b = border.all;

        for (let i = row[0] + 1; i <= row[1] + 1; i++) {

          for (let y = column[0] + 1; y <= column[1] + 1; y++) {

            let border = {};

            border['top'] = b;

            border['bottom'] = b;

            border['left'] = b;

            border['right'] = b;

            worksheet.getCell(i, y).border = border;

            // console.log(i, y, worksheet.getCell(i, y).border)

          }

        }

      } else if (border.top) {

        //上边框

        let b = border.top;

        let i = row[0] + 1;

        for (let y = column[0] + 1; y <= column[1] + 1; y++) {

          let border = {};

          border['top'] = b;

          worksheet.getCell(i, y).border = border;

          // console.log(i, y, worksheet.getCell(i, y).border)

        }

      } else if (border.right) {

        //右边框

        let b = border.right;

        for (let i = row[0] + 1; i <= row[1] + 1; i++) {

          let y = column[1] + 1;

          let border = {};

          border['right'] = b;

          worksheet.getCell(i, y).border = border;

          // console.log(i, y, worksheet.getCell(i, y).border)

        }

      } else if (border.bottom) {

        //下边框

        let b = border.bottom;

        let i = row[1] + 1;

        for (let y = column[0] + 1; y <= column[1] + 1; y++) {

          let border = {};



          border['bottom'] = b;

          worksheet.getCell(i, y).border = border;

          // console.log(i, y, worksheet.getCell(i, y).border)

        }

      } else if (border.left) {

        //左边框

        let b = border.left;

        for (let i = row[0] + 1; i <= row[1] + 1; i++) {

          let y = column[0] + 1;

          let border = {};

          border['left'] = b;

          worksheet.getCell(i, y).border = border;

          // console.log(i, y, worksheet.getCell(i, y).border)

        }

      } else if (border.outside) {

        //外边框

        let b = border.outside;

        for (let i = row[0] + 1; i <= row[1] + 1; i++) {

          for (let y = column[0] + 1; y <= column[1] + 1; y++) {

            let border = {};

            if (i === rowBegin + 1) {

              border['top'] = b;

            }

            if (i === rowEnd + 1) {

              border['bottom'] = b;

            }

            if (y === colBegin + 1) {

              border['left'] = b;

            }

            if (y === colEnd + 1) {

              border['right'] = b;

            }

            let border1 = worksheet.getCell(i, y).border;

            worksheet.getCell(i, y).border = mergeCellBorder(border1, border);

            // console.log(i, y, worksheet.getCell(i, y).border)

          }

        }

      } else if (border.inside) {

        //内边框

        let b = border.inside;

        for (let i = row[0] + 1; i <= row[1] + 1; i++) {

          for (let y = column[0] + 1; y <= column[1] + 1; y++) {

            let border = {};

            if (i !== rowBegin + 1) {

              border['top'] = b;

            }

            if (i !== rowEnd + 1) {

              border['bottom'] = b;

            }

            if (y !== colBegin + 1) {

              border['left'] = b;

            }

            if (y !== colEnd + 1) {

              border['right'] = b;

            }

            let border1 = worksheet.getCell(i, y).border;

            worksheet.getCell(i, y).border = mergeCellBorder(border1, border);

            // console.log(i, y, worksheet.getCell(i, y).border)

          }

        }

      } else if (border.horizontal) {

        //内侧水平边框

        let b = border.horizontal;

        for (let i = row[0] + 1; i <= row[1] + 1; i++) {

          for (let y = column[0] + 1; y <= column[1] + 1; y++) {

            let border = {};

            if (i === rowBegin + 1) {

              border['bottom'] = b;

            } else if (i === rowEnd + 1) {

              border['top'] = b;

            } else {

              border['top'] = b;

              border['bottom'] = b;

            }

            let border1 = worksheet.getCell(i, y).border;

            worksheet.getCell(i, y).border = mergeCellBorder(border1, border);

            // console.log(i, y, worksheet.getCell(i, y).border)

          }

        }

      } else if (border.vertical) {

        //内侧垂直边框

        let b = border.vertical;

        for (let i = row[0] + 1; i <= row[1] + 1; i++) {

          for (let y = column[0] + 1; y <= column[1] + 1; y++) {

            let border = {};

            if (y === colBegin + 1) {

              border['right'] = b;

            } else if (y === colEnd + 1) {

              border['left'] = b;

            } else {

              border['left'] = b;

              border['right'] = b;

            }

            let border1 = worksheet.getCell(i, y).border;

            worksheet.getCell(i, y).border = mergeCellBorder(border1, border);

            // console.log(i, y, worksheet.getCell(i, y).border)

          }

        }

      } else if (border.none) {

        //当luckysheet边框为border-none的时候表示没有边框 则将对应的单元格border清空

        for (let i = row[0] + 1; i <= row[1] + 1; i++) {

          for (let y = column[0] + 1; y <= column[1] + 1; y++) {

            worksheet.getCell(i, y).border = {};

            // console.log(i, y, worksheet.getCell(i, y).border)

          }

        }

      }

    }

    if (elem.rangeType === 'cell') {

      // col_index: 2

      // row_index: 1

      // b: {

      //   color: '#d0d4e3'

      //   style: 1

      // }

      const { col_index, row_index } = elem.value;

      const borderData = Object.assign({}, elem.value);

      delete borderData.col_index;

      delete borderData.row_index;

      let border = addborderToCell(borderData, row_index, col_index);

      let border1 = worksheet.getCell(row_index + 1, col_index + 1).border;

      worksheet.getCell(row_index + 1, col_index + 1).border = mergeCellBorder(border1, border);

      // console.log(row_index + 1, col_index + 1, worksheet.getCell(row_index + 1, col_index + 1).border)

    }

  });

};



/**

 * 设置带样式的值

 * @param cellArr

 * @param worksheet

 */

var setStyleAndValue = function (cellArr, worksheet) {

  if (!Array.isArray(cellArr)) return;

  cellArr.forEach(function (row, rowid) {

    row.every(function (cell, columnid) {

      if (!cell) return true;

      let fill = fillConvert(cell.bg);



      let font = fontConvert(cell.ff, cell.fc, cell.bl, cell.it, cell.fs, cell.cl, cell.un);

      let alignment = alignmentConvert(cell.vt, cell.ht, cell.tb, cell.tr);

      let value = '';



      if (cell.f) {

        value = { formula: cell.f, result: cell.v };

      } else if (!cell.v && cell.ct && cell.ct.s) {

        // xls转为xlsx之后,内部存在不同的格式,都会进到富文本里,即值不存在与cell.v,而是存在于cell.ct.s之后

        let richText = [];

        let cts = cell.ct.s;

        for (let i = 0; i < cts.length; i++) {

          let rt = {

            text: cts[i].v,

            font: fontConvert(cts[i].ff, cts[i].fc, cts[i].bl, cts[i].it, cts[i].fs, cts[i].cl, cts[i].un),

          };

          richText.push(rt);

        }

        value = {

          richText: richText,

        };

      } else {

        //设置值为数字格式

        if (cell.v !== undefined && cell.v !== '') {

          var v = +cell.v;

          if (isNaN(v)) v = cell.v;

          value = v;

        }

      }

      //  style 填入到_value中可以实现填充色

      let letter = createCellPos(columnid);

      let target = worksheet.getCell(letter + (rowid + 1));

      // console.log('1233', letter + (rowid + 1))

      for (const key in fill) {

        target.fill = fill;

        break;

      }

      target.font = font;

      target.alignment = alignment;

      target.value = value;



      try {

        //设置单元格格式

        target.numFmt = cell.ct.fa;

        if (cell.ct.fa === '拾元') {

//windows和wps的金额大写公式是这个,但是excel导出经过二进制流转码后,公式变了。你们可以尝试后有效解决方案可以艾特我,万分感谢你们

 // if (cell.ct.fa === '拾元') target.numFmt = '[DBNum2]G/通用格式;[红色][DBNum2]G/通用格式';

          target.numFmt = cell.m;//这里写死金额,导出就不是动态了

        }

      } catch (e) {

        console.warn(e);

      }



      return true;

    });

  });

};



/**

 * 设置图片

 * @param images

 * @param worksheet

 * @param workbook

 */

var setImages = function (images, worksheet, workbook) {

  if (typeof images != 'object') return;

  for (let key in images) {

    // console.log(images[key]);

    // "..."

    // 通过 base64  将图像添加到工作簿

    const myBase64Image = images[key].src;

    //位置

    const tl = { col: images[key].default.left / 72, row: images[key].default.top / 19 };

    // 大小

    const ext = { width: images[key].default.width, height: images[key].default.height };

    const imageId = workbook.addImage({

      base64: myBase64Image,

      //extension: 'png',

    });

    worksheet.addImage(imageId, {

      tl: tl,

      ext: ext,

    });

  }

};



/**

 * 冻结行列

 * @param frozen

 * @param worksheet

 */

var setFrozen = function (frozen = {}, worksheet) {

  switch (frozen.type) {

    // 冻结首行

    case 'row': {

      worksheet.views = [{ state: 'frozen', xSplit: 0, ySplit: 1 }];

      break;

    }

    // 冻结首列

    case 'column': {

      worksheet.views = [{ state: 'frozen', xSplit: 1, ySplit: 0 }];

      break;

    }

    // 冻结行列

    case 'both': {

      worksheet.views = [{ state: 'frozen', xSplit: 1, ySplit: 1 }];

      break;

    }

    // 冻结行到选区

    case 'rangeRow': {

      let row = frozen.range.row_focus + 1;

      worksheet.views = [{ state: 'frozen', xSplit: 0, ySplit: row }];

      break;

    }

    // 冻结列到选区

    case 'rangeColumn': {

      let column = frozen.range.column_focus + 1;

      worksheet.views = [{ state: 'frozen', xSplit: column, ySplit: 0 }];

      break;

    }

    // 冻结行列到选区

    case 'rangeBoth': {

      let row = frozen.range.row_focus + 1;

      let column = frozen.range.column_focus + 1;

      worksheet.views = [{ state: 'frozen', xSplit: column, ySplit: row }];

    }

  }

};



/**

 * 行隐藏

 * @param rowhidden

 * @param worksheet

 */

var setRowHidden = function (rowhidden = {}, worksheet) {

  for (const key in rowhidden) {

    //如果当前行没有内容则隐藏不生效

    const row = worksheet.getRow(parseInt(key) + 1);

    row.hidden = true;

  }

};



/**

 * 列隐藏

 * @param colhidden

 * @param worksheet

 */

var setColHidden = function (colhidden = {}, worksheet) {

  for (const key in colhidden) {

    const column = worksheet.getColumn(parseInt(key) + 1);

    column.hidden = true;

  }

};



/**

 * 自动筛选器

 * @param filter

 * @param worksheet

 */

var setFilter = function (filter = {}, worksheet) {

  if (Object.keys(filter).length === 0) return;

  const from = {

    row: filter.row[0] + 1,

    column: filter.column[0] + 1,

  };



  const to = {

    row: filter.row[1] + 1,

    column: filter.column[1] + 1,

  };



  worksheet.autoFilter = {

    from: from,

    to: to,

  };

};



var fillConvert = function (bg) {

  if (!bg) {

    return {};

  }

  // const bgc = bg.replace('#', '')

  let fill = {

    type: 'pattern',

    pattern: 'solid',

    fgColor: { argb: bg.startsWith('#') ? bg.replace('#', '') : colorRGBtoHex(bg).replace('#', '') },

  };

  return fill;

};



var fontConvert = function (ff = 0, fc = '#000000', bl = 0, it = 0, fs = 10, cl = 0, ul = 0) {

  // luckysheet:ff(样式), fc(颜色), bl(粗体), it(斜体), fs(大小), cl(删除线), ul(下划线)

  const luckyToExcel = {

    0: '微软雅黑',

    1: '宋体(Song)',

    2: '黑体(ST Heiti)',

    3: '楷体(ST Kaiti)',

    4: '仿宋(ST FangSong)',

    5: '新宋体(ST Song)',

    6: '华文新魏',

    7: '华文行楷',

    8: '华文隶书',

    9: 'Arial',

    10: 'Times New Roman ',

    11: 'Tahoma ',

    12: 'Verdana',

    num2bl: function (num) {

      return num !== 0;

    },

  };

  // 出现Bug,导入的时候ff为luckyToExcel的val



  let font = {

    name: typeof ff === 'number' ? luckyToExcel[ff] : ff,

    family: 1,

    size: fs,

    color: { argb: fc.startsWith('#') ? fc.replace('#', '') : colorRGBtoHex(fc).replace('#', '') },

    bold: luckyToExcel.num2bl(bl),

    italic: luckyToExcel.num2bl(it),

    underline: luckyToExcel.num2bl(ul),

    strike: luckyToExcel.num2bl(cl),

  };



  return font;

};



var alignmentConvert = function (vt = 'default', ht = 'default', tb = 'default', tr = 'default') {

  // luckysheet:vt(垂直), ht(水平), tb(换行), tr(旋转)

  const luckyToExcel = {

    vertical: {

      0: 'middle',

      1: 'top',

      2: 'bottom',

      default: 'middle',

    },

    horizontal: {

      0: 'center',

      1: 'left',

      2: 'right',

      default: 'center',

    },

    wrapText: {

      0: false,

      1: false,

      2: true,

      default: false,

    },

    textRotation: {

      0: 0,

      1: 45,

      2: -45,

      3: 'vertical',

      4: 90,

      5: -90,

      default: 0,

    },

  };



  let alignment = {

    vertical: luckyToExcel.vertical[vt],

    horizontal: luckyToExcel.horizontal[ht],

    wrapText: luckyToExcel.wrapText[tb],

    textRotation: luckyToExcel.textRotation[tr],

  };

  return alignment;

};



var borderConvert = function (borderType, style = 1, color = '#000') {

  // 对应luckysheet的config中borderinfo的的参数

  if (!borderType) {

    return {};

  }

  const luckyToExcel = {

    type: {

      'border-all': 'all',

      'border-top': 'top',

      'border-right': 'right',

      'border-bottom': 'bottom',

      'border-left': 'left',

      'border-outside': 'outside',

      'border-inside': 'inside',

      'border-horizontal': 'horizontal',

      'border-vertical': 'vertical',

      'border-none': 'none',

    },

    style: {

      0: 'none',

      1: 'thin',

      2: 'hair',

      3: 'dotted',

      4: 'dashDot', // 'Dashed',

      5: 'dashDot',

      6: 'dashDotDot',

      7: 'double',

      8: 'medium',

      9: 'mediumDashed',

      10: 'mediumDashDot',

      11: 'mediumDashDotDot',

      12: 'slantDashDot',

      13: 'thick',

    },

  };

  let border = {};

  border[luckyToExcel.type[borderType]] = {

    style: luckyToExcel.style[style],

    color: { argb: color.replace('#', '') },

  };

  return border;

};



function addborderToCell(borders, row_index, col_index) {

  let border = {};

  const luckyExcel = {

    type: {

      l: 'left',

      r: 'right',

      b: 'bottom',

      t: 'top',

    },

    style: {

      0: 'none',

      1: 'thin',

      2: 'hair',

      3: 'dotted',

      4: 'dashDot', // 'Dashed',

      5: 'dashDot',

      6: 'dashDotDot',

      7: 'double',

      8: 'medium',

      9: 'mediumDashed',

      10: 'mediumDashDot',

      11: 'mediumDashDotDot',

      12: 'slantDashDot',

      13: 'thick',

    },

  };

  // console.log('borders', borders)

  for (const bor in borders) {

    // console.log(bor)

    if (borders[bor].color.indexOf('rgb') === -1) {

      border[luckyExcel.type[bor]] = {

        style: luckyExcel.style[borders[bor].style],

        color: { argb: borders[bor].color.replace('#', '') },

      };

    } else {

      border[luckyExcel.type[bor]] = {

        style: luckyExcel.style[borders[bor].style],

        color: { argb: borders[bor].color },

      };

    }

  }



  return border;

}



function createCellPos(n) {

  let ordA = 'A'.charCodeAt(0);



  let ordZ = 'Z'.charCodeAt(0);

  let len = ordZ - ordA + 1;

  let s = '';

  while (n >= 0) {

    s = String.fromCharCode((n % len) + ordA) + s;



    n = Math.floor(n / len) - 1;

  }

  return s;

}



//rgb(255,255,255)转16进制 #ffffff

function colorRGBtoHex(color) {

  color = color.replace('rgb', '').replace('(', '').replace(')', '');

  var rgb = color.split(',');

  var r = parseInt(rgb[0]);

  var g = parseInt(rgb[1]);

  var b = parseInt(rgb[2]);

  return '#' + ((1 << 24) + (r << 16) + (g << 8) + b).toString(16).slice(1);

}



export { exportExcel };

js文件内容,主要处理数据验证,注意路径,可看上面的导入相对路径

/**

 * *创建单元格所在列的列的字母

 * @param {列数的index值} n

 * @returns

 */

export const createCellPos = function (n) {

  let ordA = 'A'.charCodeAt(0);



  let ordZ = 'Z'.charCodeAt(0);

  let len = ordZ - ordA + 1;

  let s = '';

  while (n >= 0) {

    s = String.fromCharCode((n % len) + ordA) + s;



    n = Math.floor(n / len) - 1;

  }

  return s;

};

/**

 * *创建单元格范围,期望得到如:A1:D6

 * @param {单元格行数组(例如:[0,3])} rowArr

 * @param {单元格列数组(例如:[5,7])} colArr

 * */

export const createCellRange = function (rowArr, colArr) {

  const startCell = createCellPos(colArr[0]) + (rowArr[0] + 1);

  const endCell = createCellPos(colArr[1]) + (rowArr[1] + 1);



  return startCell + ':' + endCell;

};



/**

 * *数据验证

 */

export const setDataValidation = function (verify, worksheet) {

  // 不存在不执行

  if (!verify) return;

  // 存在则有以下逻辑

  for (const key in verify) {

    const row_col = key.split('_');

    let cell = worksheet.getCell(Number(row_col[0]) + 1, Number(row_col[1]) + 1);

    let { type, type2, value1, value2 } = verify[key];

    //下拉框--list

    if (type == 'dropdown') {

      cell.dataValidation = {

        type: 'list',

        allowBlank: true,

        formulae: [`${value1}`],

      };

      continue;

    }

    //整数--whole

    if (type == 'number_integer') {

      cell.dataValidation = {

        type: 'whole',

        operator: setOperator(type2),

        showErrorMessage: true,

        formulae: value2 ? [Number(value1), Number(value2)] : [Number(value1)],

        errorStyle: 'error',

        errorTitle: '警告',

        error: errorMsg(type2, type, value1, value2),

      };

      continue;

    }

    //小数-数字--decimal

    if (type == 'number_decimal' || 'number') {

      cell.dataValidation = {

        type: 'decimal',

        operator: setOperator(type2),

        allowBlank: true,

        showInputMessage: true,

        formulae: value2 ? [Number(value1), Number(value2)] : [Number(value1)],

        promptTitle: '警告',

        prompt: errorMsg(type2, type, value1, value2),

      };

      continue;

    }

    //长度受控的文本--textLength

    if (type == 'text_length') {

      cell.dataValidation = {

        type: 'textLength',

        operator: setOperator(type2),

        showErrorMessage: true,

        allowBlank: true,

        formulae: value2 ? [Number(value1), Number(value2)] : [Number(value1)],

        promptTitle: '错误提示',

        prompt: errorMsg(type2, type, value1, value2),

      };

      continue;

    }

    //文本的内容--text_content

    if (type == 'text_content') {

      cell.dataValidation = {};

      continue;

    }

    //日期--date

    if (type == 'date') {

      cell.dataValidation = {

        type: 'date',

        operator: setDateOperator(type2),

        showErrorMessage: true,

        allowBlank: true,

        promptTitle: '错误提示',

        prompt: errorMsg(type2, type, value1, value2),

        formulae: value2 ? [new Date(value1), new Date(value2)] : [new Date(value1)],

      };

      continue;

    }

    //有效性--custom;type2=="phone"/"card"

    if (type == 'validity') {

      // cell.dataValidation = {

      //   type: 'custom',

      //   allowBlank: true,

      //   formulae: [type2]

      // };

      continue;

    }

    //多选框--checkbox

    if (type == 'checkbox') {

      cell.dataValidation = {};

      continue;

    }

  }

};

//类型type值为"number"/"number_integer"/"number_decimal"/"text_length"时,type2值可为

function setOperator(type2) {

  let transToOperator = {

    bw: 'between',

    nb: 'notBetween',

    eq: 'equal',

    ne: 'notEqual',

    gt: 'greaterThan',

    lt: 'lessThan',

    gte: 'greaterThanOrEqual',

    lte: 'lessThanOrEqual',

  };

  return transToOperator[type2];

}

//数字错误性提示语

function errorMsg(type2, type, value1 = '', value2 = '') {

  const tip = '你输入的不是';

  const tip1 = '你输入的不是长度';

  let errorTitle = {

    bw: `${type == 'text_length' ? tip1 : tip}介于${value1}和${value2}之间的${numType(type)}`,

    nb: `${type == 'text_length' ? tip1 : tip}不介于${value1}和${value2}之间的${numType(type)}`,

    eq: `${type == 'text_length' ? tip1 : tip}等于${value1}的${numType(type)}`,

    ne: `${type == 'text_length' ? tip1 : tip}不等于${value1}的${numType(type)}`,

    gt: `${type == 'text_length' ? tip1 : tip}大于${value1}的${numType(type)}`,

    lt: `${type == 'text_length' ? tip1 : tip}小于${value1}的${numType(type)}`,

    gte: `${type == 'text_length' ? tip1 : tip}大于等于${value1}的${numType(type)}`,

    lte: `${type == 'text_length' ? tip1 : tip}小于等于${value1}的${numType(type)}`,

    //日期

    bf: `${type == 'text_length' ? tip1 : tip}早于${value1}的${numType(type)}`,

    nbf: `${type == 'text_length' ? tip1 : tip}不早于${value1}的${numType(type)}`,

    af: `${type == 'text_length' ? tip1 : tip}晚于${value1}的${numType(type)}`,

    naf: `${type == 'text_length' ? tip1 : tip}不晚于${value1}的${numType(type)}`,

  };



  return errorTitle[type2];

}

// 数字类型(整数,小数,十进制数)

function numType(type) {

  let num = {

    number_integer: '整数',

    number_decimal: '小数',

    number: '数字',

    text_length: '文本',

    date: '日期',

  };

  return num[type];

}

//类型type值为date时

function setDateOperator(type2) {

  let transToOperator = {

    bw: 'between',

    nb: 'notBetween',

    eq: 'equal',

    ne: 'notEqual',

    bf: 'greaterThan',

    nbf: 'lessThan',

    af: 'greaterThanOrEqual',

    naf: 'lessThanOrEqual',

  };

  return transToOperator[type2];

}



/**

 * *条件格式设置

 */

export const setConditions = function (conditions, worksheet) {

  //条件格式不存在,则不执行后续代码

  if (conditions == undefined) return;



  //循环遍历规则列表

  conditions.forEach((item) => {

    let ruleObj = {

      ref: createCellRange(item.cellrange[0].row, item.cellrange[0].column),

      rules: [],

    };

    console.log(item.conditionName == 'greaterThan', item.conditionName);

    //lucksheet对应的为----突出显示单元格规则和项目选区规则

    if (item.type == 'default') {

      //excel中type为cellIs的条件下

      if (

        item.conditionName == 'equal' ||

        item.conditionName == 'greaterThan' ||

        item.conditionName == 'lessThan' ||

        item.conditionName == 'betweenness'

      ) {

        console.log(item.conditionName == 'greaterThan', item.conditionName);

        ruleObj.rules = setDefaultRules({

          type: 'cellIs',

          operator: item.conditionName == 'betweenness' ? 'between' : item.conditionName,

          condvalue: item.conditionValue,

          colorArr: [item.format.cellColor, item.format.textColor],

        });

        worksheet.addConditionalFormatting(ruleObj);

      }

      //excel中type为containsText的条件下

      if (item.conditionName == 'textContains') {

        ruleObj.rules = [

          {

            type: 'containsText',

            operator: 'containsText', //表示如果单元格值包含在text 字段中指定的值,则应用格式

            text: item.conditionValue[0],

            style: setStyle([item.format.cellColor, item.format.textColor]),

          },

        ];

        worksheet.addConditionalFormatting(ruleObj);

      }

      //发生日期--时间段

      if (item.conditionName == 'occurrenceDate') {

        ruleObj.rules = [

          {

            type: 'timePeriod',

            timePeriod: 'today', //表示如果单元格值包含在text 字段中指定的值,则应用格式

            style: setStyle([item.format.cellColor, item.format.textColor]),

          },

        ];

        worksheet.addConditionalFormatting(ruleObj);

      }

      //重复值--唯一值

      // if(item.conditionName=='duplicateValue'){

      //     ruleObj.rules = [

      //             {

      //                 type:'expression',

      //                 formulae:'today', //表示如果单元格值包含在text 字段中指定的值,则应用格式

      //                 style: setStyle([item.format.cellColor,item.format.textColor])

      //             }

      //         ]

      //     worksheet.addConditionalFormatting(ruleObj)

      // }

      //项目选区规则--top10前多少项的操作

      if (item.conditionName == 'top10' || item.conditionName == 'top10%' || item.conditionName == 'last10' || item.conditionName == 'last10%') {

        ruleObj.rules = [

          {

            type: 'top10',

            rank: item.conditionValue[0], //指定格式中包含多少个顶部(或底部)值

            percent: item.conditionName == 'top10' || 'last10' ? false : true,

            bottom: item.conditionName == 'top10' || 'top10%' ? false : true,

            style: setStyle([item.format.cellColor, item.format.textColor]),

          },

        ];

        worksheet.addConditionalFormatting(ruleObj);

      }

      //项目选区规则--高于/低于平均值的操作

      if (item.conditionName == 'AboveAverage' || item.conditionName == 'SubAverage') {

        console.log(item.conditionName == 'greaterThan', item.conditionName);

        ruleObj.rules = [

          {

            type: 'aboveAverage',

            aboveAverage: item.conditionName == 'AboveAverage' ? true : false,

            style: setStyle([item.format.cellColor, item.format.textColor]),

          },

        ];

        worksheet.addConditionalFormatting(ruleObj);

      }

      return;

    }



    //数据条

    if (item.type == 'dataBar') {

      ruleObj.rules = [

        {

          type: 'dataBar',

          style: {},

        },

      ];

      worksheet.addConditionalFormatting(ruleObj);

      return;

    }

    //色阶

    if (item.type == 'colorGradation') {

      ruleObj.rules = [

        {

          type: 'colorScale',

          color: item.format,

          style: {},

        },

      ];

      worksheet.addConditionalFormatting(ruleObj);

      return;

    }

    //图标集

    if (item.type == 'icons') {

      ruleObj.rules = [

        {

          type: 'iconSet',

          iconSet: item.format.len,

        },

      ];

      worksheet.addConditionalFormatting(ruleObj);

      return;

    }

  });

};

/**

 *

 * @param {

 *  type:lucketsheet对应的条件导出类型;

 *  operator:excel对应的条件导入类型;

 *  condvalue:1个公式字符串数组,返回要与每个单元格进行比较的值;

 *  colorArr:颜色数组,第一项为单元格填充色,第二项为单元格文本颜色

 * } obj

 * @returns

 */

function setDefaultRules(obj) {

  let rules = [

    {

      type: obj.type,

      operator: obj.operator,

      formulae: obj.condvalue,

      style: setStyle(obj.colorArr),

    },

  ];

  return rules;

}

/**

 *

 * @param {颜色数组,第一项为单元格填充色,第二项为单元格文本颜色} colorArr

 */

function setStyle(colorArr) {

  return {

    fill: { type: 'pattern', pattern: 'solid', bgColor: { argb: colorArr[0].replace('#', '') } },

    font: { color: { argb: colorArr[1].replace('#', '') } },

  };

}

 我只是搬运工,参考了好多文字,部分已忘记是哪里摘抄的

这个是处理边框的:使用exceljs导出luckysheet表格(合并,边框,行高,列宽,冻结,行列隐藏,筛选,图片)_xlsx合并单元格js-CSDN博客

这个是金额大写的: luckysheet添加文本后缀(kg)、金额大写等单元格格式_luckysheet 设置单元格格式-CSDN博客

  • 22
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值