0

当我应用条件格式时,我将其存储在 conditionalFormatCols 和 conditionalFormatRows 变量中。然后我对这些变量使用 delete() 方法,但这不会删除单元格上的条件格式。如何删除条件格式使其不再显示在工作簿中?

let eventResult;
let navAidIsOn = false;
let conditionalFormatCols;
let conditionalFormatRows;

async function navAid() {
  await Excel.run(async (context) => {
    if (!navAidIsOn) {
      applyConditionalFormatting();
      const sheet = context.workbook.worksheets.getActiveWorksheet();
      eventResult = sheet.onSelectionChanged.add(navAidListener);
      navAidIsOn = !navAidIsOn;
      
    } else {
      turnNavAidOff();
    }
  });
}

async function turnNavAidOff(){
  await Excel.run(eventResult.context ,async (context) => {
    eventResult.remove()

这里我尝试使用 delete() 方法

    conditionalFormatCols.delete();
    conditionalFormatRows.delete();

    await context.sync();
    
    navAidIsOn = !navAidIsOn;
  });
}

async function navAidListener() {
  applyConditionalFormatting();
}

async function applyConditionalFormatting() {
  await Excel.run(async (context) => {
    const sheet = context.workbook.worksheets.getActiveWorksheet();

    let ranges;
    let rangeArray = [];
    await context.sync();

    let columns;
    let rows;
    

    ranges = context.workbook.getSelectedRanges();
    await context.sync();

    ranges.load("address");
    await context.sync();
    let rangeStrs = ranges.address.split(",");
    rangeStrs.forEach((rangeStr) => {
      rangeArray.push(sheet.getRange(rangeStr).load("columnIndex, rowIndex, rowCount, columnCount"));
    });
    await context.sync();

    rangeArray.forEach(async (range) => {
      columns = sheet.getRangeByIndexes(0, range.columnIndex, 1048576, range.columnCount);
      rows = sheet.getRangeByIndexes(range.rowIndex, 0, range.rowCount, 16384);
      await context.sync();

      conditionalFormatCols = columns.conditionalFormats.add(Excel.ConditionalFormatType.custom);
      conditionalFormatCols.custom.rule.formula = "TRUE";
      conditionalFormatCols.custom.format.fill.color = "#D2F0E0";

      conditionalFormatRows = rows.conditionalFormats.add(Excel.ConditionalFormatType.custom);
      conditionalFormatRows.custom.rule.formula = "TRUE";
      conditionalFormatRows.custom.format.fill.color = "#D2F0E0";

      await context.sync();
    });
  });
}
4

0 回答 0