GuidesUniver SheetsFeaturesCoreRange & Selection & Cell

Range & Selection & Cell

Range

A range refers to a rectangular area in a worksheet, determined by the starting row number, starting column number, length and width, or ending row number and ending column number.

Most operations in a spreadsheet can be performed through the Range API, such as setting values, getting values, setting styles, getting styles, etc.

Facade API

Create a Range

To get a range you need to know the starting row number, starting column number, length and width.

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
// Create a range of A1 cell:
const range = sheet.getRange(0, 0, 1, 1);
 
// Creates a range of A1:B2:
const range2 = sheet.getRange(0, 0, 2, 2);

Starting from 0.2.15, getRange supports using A1 notation to get ranges.

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
// Get the A1:B2 range on named Sheet1
const range1 = sheet.getRange('Sheet1!A1:B2');
 
// Get a single cell A1
const range2 = sheet.getRange('A1');
 
// Get the A1:B2 range
const range3 = sheet.getRange('A1:B2');
 
// Get the range of column A
const range4 = sheet.getRange('A:A');
 
// Get the range of row 1
const range5 = sheet.getRange('1:1');

Get Range Data

Get the value of the first cell in the range

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
const value = range.getValue();

Get all cell values in the range

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
range.forEach(( row, column, cell) => {
  console.log( row, column, cell);
});

Get all formulas in the range

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
console.log(range.getFormulas());

Set Range Value

Set a single value

If a value or cell object is passed in, all cells in the range will be overwritten. If it starts with =, it will be interpreted as a formula.

For example, to set the value of A1:B2 to Hello, Univer:

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
range.setValue('Hello, Univer');

Set the value of A1+B1 to the formula:

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
range.setValue('=A1+B1');

Set the value of A1:B2 to the cell object:

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
range.setValue({
  v: 'Hello, Univer',
  custom: {
      key: 'value',
  },
});
Set multiple values with an array

The length and width of the array must match the length and width of the range.

You can pass in cell values or cell objects.

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
range.setValues([
  ['A1', 'B1'],
  ['A2', 'B2'],
]);
 
range.setValues([
  [{ v: 'A1' }, { v: 'B1' }],
  [{ v: 'A2' }, { v: 'B2' }],
]);
Set multiple values with an object

If an object is passed in, the primary index of the object represents the row number, and the secondary index represents the column number, and the length and width of the range do not need to match.

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
range.setValues({
  0: {
    0: 'A1',
    1: 'B1',
  },
  1: {
    0: 'A2',
    1: 'B2',
  },
});

Get Range Style

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
const style = range.getCellStyleData();

Set Range Style

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
range
  .setFontWeight('bold')
  .setFontLine('underline')
  .setFontFamily('Arial')
  .setFontSize(24)
  .setFontColor('red');

Clear Range Style

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
range
  .setFontWeight(null)
  .setFontLine(null)
  .setFontFamily(null)
  .setFontSize(null)
  .setFontColor(null);

Whether the range is merged

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
 
const range = sheet.getRange(0, 0, 2, 2);
const isMerged = range.isMerged();

Get the coordinates of the range

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
const range = sheet.getRange(0, 0, 2, 2);
 
univerAPI.getHooks().onRendered(() => {
  const rect = range.getCellRect(); // width、heigh、left、right、top、bottom、x、y
  console.log(rect);
});

Get the merge information and coordinates of the range at the same time

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();
const range = sheet.getRange(0, 0, 2, 2);
 
univerAPI.getHooks().onRendered(() => {
  const cell = range.getCell();
  console.log(cell);
});

Selection

Univer Sheets support multiple constituencies, so a constituency is an array of ranges, and you can manipulate the constituency data through the range API.

We also provide APIs to get the current selection, set the selection, and listen for changes to the selection.

Facade API

Get Active Selection

const sheet = univerAPI.getActiveWorkbook().getActiveSheet();\
 
univerAPI.getHooks().onRendered(() => {
  const selection = sheet.getSelection();
  console.log(selection);
 
  const range = selection.getActiveRange();
  console.log(range);
});

Set Selection

Set A1:B2 as the selection

import { SetSelectionsOperation } from '@univerjs/sheets'
 
univerAPI.executeCommand(SetSelectionsOperation.id, {
  unitId,
  subUnitId,
  selections: [{
    range: {
      startRow: 0,
      startColumn: 0,
      endRow: 1,
      endColumn: 1,
      rangeType: 0,
    },
  }],
  type: 2,
})

Listen for Selection Changes

const activeWorkbook = univerAPI.getActiveWorkbook();
activeWorkbook.onSelectionChange((selection) => {
  console.log(selection);
});

Cell

Cell data is stored in the worksheet as a two-dimensional Map, with the first and second indexes representing the row number and column number respectively.

The following is a typical cell object:

{
  v: 'Hello, Univer',
  s: 'styleId',
  t: CellValueType.STRING
}

For detailed field descriptions, please refer to Configure Cell Data.

ℹ️

Cell operations can be regarded as operations on a range of rows and columns with a height of 1 and a width of 1. For the operation range, please refer to Range.

ℹ️

The Univer API plugin will also store the extended cell attributes in the resources property of the Workbook, please refer to Plugin Custom Model.

Cell PointerMove Event

The onCellPointerMove event is fired when a pointer changes coordinates.

univerAPI.getSheetHooks().onCellPointerMove((cell) => {
  // Get the cell currently pointed to by the mouse
  console.log(cell);
})

Cell PointerOver Event

The onCellPointerOver event is fired when a pointer is moved into a cell’s hit test boundaries.

univerAPI.getSheetHooks().onCellPointerOver((cell) => {
  // Get the cell currently pointed to by the mouse
  console.log(cell);
})

Cell DragOver Event

The onCellDragOver event is fired when an element or text selection is being dragged into a cell’s hit test boundaries.

univerAPI.getSheetHooks().onCellDragOver((cell) => {
  // Get the cell currently pointed to by the mouse
  console.log(cell);
})

Cell Drop Event

The onCellDrop event is fired when an element or text selection is being dropped on the cell.

univerAPI.getSheetHooks().onCellDrop((cell) => {
  // Get the cell currently pointed to by the mouse
  console.log(cell);
})

Cell Hover Event

univerAPI.getActiveWorkbook().onCellHover((cell) => {
  // ζ‹Ώεˆ°ε½“ε‰ιΌ ζ ‡ζŒ‡ε‘ηš„ε•ε…ƒζ Ό
  console.log(cell);
})

Cell Click Event

univerAPI.getActiveWorkbook().onCellClick((cell) => {
  // ζ‹Ώεˆ°ε½“ε‰ιΌ ζ ‡η‚Ήε‡»ηš„ε•ε…ƒζ Ό
  console.log(cell);
})

Cell Render Event

The onCellRender event is fired when a cell is rendered.

univerAPI.getSheetHooks().onCellRender((params) => {
  console.log(params);
})

Case 1, fixed position rendering, adding rows will not affect the rendering position

// Fixed position rendering
univerAPI.getSheetHooks().onCellRender([{
    drawWith: (ctx, info, skeleton, spreadsheets)=>{
        const {row, col} = info;
        // Update to any cell location you want
        if(row === 1 && col === 1){
            const { primaryWithCoord } = info;
            const {startX, startY} = primaryWithCoord
            ctx.fillText('βœ…', startX, startY+10)
        }
    }
}])
 
// Refresh canvas
univerAPI.getActiveWorkbook().getActiveSheet().refreshCanvas()

Case 2, rendering by markup, the mark position will change with the row and column, and the rendering position will also change accordingly

// Mark in advance
univerAPI.getActiveWorkbook().getActiveSheet().getRange('B2').setValue({custom:{key:'needCheck'}})
// Rendering by markup
univerAPI.getSheetHooks().onCellRender([{
    drawWith: (ctx, info, skeleton, spreadsheets)=>{
        const {row, col, data} = info;
        // Update to any cell location you want
        if(data?.custom?.key === 'needCheck'){
            const { primaryWithCoord } = info;
            const {startX, startY} = primaryWithCoord
            ctx.fillText('βœ…', startX, startY+10)
        }
    }
}])
 
// Refresh canvas
univerAPI.getActiveWorkbook().getActiveSheet().refreshCanvas()

Start editing cell

const workbook = univerAPI.getActiveWorkbook();
 
univerAPI.getHooks().onRendered(() => {
  workbook.startEditing();
});

End editing cell

// Pass in true to commit the edit, pass in false to cancel the edit
// this is an async function
await workbook.endEditing(true);

Before editing cell event

The onBeforeCellEdit event is fired before editing a cell.

univerAPI.getSheetHooks().onBeforeCellEdit((params) => {
  console.info('Before editing cell',params)
})

After editing cell event

The onAfterCellEdit event is fired after editing a cell.

univerAPI.getSheetHooks().onAfterCellEdit((params) => {
  console.info('After editing cell',params)
})

Was this page helpful?