Rows and columns in Angular Spreadsheet component
2 Jul 202424 minutes to read
Spreadsheet is a tabular format consisting of rows and columns. The intersection point of rows and columns are called as cells. The list of operations that you can perform in rows and columns are,
- Insert
- Delete
- Show and Hide
Insert
You can insert rows or columns anywhere in a spreadsheet. Use the allowInsert
property to enable or disable the insert option in Spreadsheet.
Row
The rows can be inserted in the following ways,
- Using
insertRow
method, you can insert the rows once the component is loaded. - Using context menu, insert the empty rows in the desired position.
The following code example shows the options for inserting rows in the spreadsheet.
import { NgModule } from '@angular/core'
import { BrowserModule } from '@angular/platform-browser'
import { SpreadsheetAllModule } from '@syncfusion/ej2-angular-spreadsheet'
import { Component, ViewChild } from '@angular/core';
import { SpreadsheetComponent, RowModel } from '@syncfusion/ej2-angular-spreadsheet';
import { dataSource } from './datasource';
@Component({
imports: [
SpreadsheetAllModule
],
standalone: true,
selector: 'app-container',
template: `<ejs-spreadsheet #spreadsheet (created)="created()" [showFormulaBar]="false"
[showSheetTabs]="false" [showRibbon]="false">
<e-sheets>
<e-sheet>
<e-ranges>
<e-range [dataSource]="data" startCell="B1"></e-range>
</e-ranges>
<e-columns>
<e-column [width]=20></e-column>
<e-column [width]=90></e-column>
<e-column [width]=220></e-column>
<e-column [width]=90></e-column>
<e-column [width]=140></e-column>
<e-column [width]=90></e-column>
<e-column [width]=100></e-column>
<e-column [width]=100></e-column>
</e-columns>
</e-sheet>
</e-sheets>
</ejs-spreadsheet>`
})
export class AppComponent {
@ViewChild('spreadsheet')
spreadsheetObj: SpreadsheetComponent | undefined;
data: object[] = dataSource;
// Rows model that is going to insert dynamically
rowsModel: RowModel[] = [
{
index: 9, // Need to specify the index for the first row collection, the specified rows will be inserted in this index.
cells: [{ value: '' }, { value: '8' }, { value: 'Northwoods Cranberry Sauce' }, { value: '3' }, { value: '12 - 12 oz jars' },
{ value: '40.00' }, { value: '6' }, { value: 'false' }]
},
{
cells: [{ value: '' }, { value: '9' }, { value: 'Mishi Kobe Niku' }, { value: '4' }, { value: '18 - 500 g pkgs.' },
{ value: '97.00' }, { value: '29' }, { value: 'true' }]
}
];
created() {
// Applies style formatting before inserting the rows
this.spreadsheetObj!.cellFormat({ fontWeight: 'bold', textAlign: 'center' }, 'B1:H1');
// inserting a empty row at 0th index
this.spreadsheetObj!.insertRow();
// inserting 2 rows at the 9th index with data
this.spreadsheetObj!.insertRow(this.rowsModel);
// Applies style formatting after the rows are inserted
this.spreadsheetObj!.cellFormat({ textAlign: 'center' }, 'B3:B12');
this.spreadsheetObj!.cellFormat({ textAlign: 'center' }, 'D3:D12');
this.spreadsheetObj!.cellFormat({ textAlign: 'center' }, 'F3:H12');
}
}
import { bootstrapApplication } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import 'zone.js';
bootstrapApplication(AppComponent).catch((err) => console.error(err));
Column
The columns can be inserted in the following ways,
- Using
insertColumn
method, you can insert the columns once the component is loaded. - Using context menu, insert the empty columns in the desired position.
The following code example shows the options for inserting columns in the spreadsheet.
import { NgModule } from '@angular/core'
import { BrowserModule } from '@angular/platform-browser'
import { SpreadsheetAllModule } from '@syncfusion/ej2-angular-spreadsheet'
import { Component, ViewChild } from '@angular/core';
import { SpreadsheetComponent, CellModel, getCellAddress } from '@syncfusion/ej2-angular-spreadsheet';
import { dataSource } from './datasource';
@Component({
imports: [
SpreadsheetAllModule
],
standalone: true,
selector: 'app-container',
template: `<ejs-spreadsheet #spreadsheet (created)="created()" [showFormulaBar]="false" [showSheetTabs]="false"
[showRibbon]="false">
<e-sheets>
<e-sheet>
<e-ranges>
<e-range [dataSource]="data" startCell="A2"></e-range>
</e-ranges>
<e-columns>
<e-column [width]=90></e-column>
<e-column [width]=220></e-column>
<e-column [width]=90></e-column>
<e-column [width]=140></e-column>
<e-column [width]=100></e-column>
<e-column [width]=100></e-column>
</e-columns>
</e-sheet>
</e-sheets>
</ejs-spreadsheet>`
})
export class AppComponent {
@ViewChild('spreadsheet')
spreadsheetObj: SpreadsheetComponent | undefined;
data: object[] = dataSource;
// Cells model that you are going to update in the inserted 5th column dynamically
cellsModel: CellModel[] = [{ value: 'Unit Price', style: { fontWeight: 'bold', textAlign: 'center' } }, { value: '18.00' },
{ value: '19.00' }, { value: '10.00' }, { value: '22.00' }, { value: '21.35' }, { value: '25.00' }, { value: '30.00' },
{ value: '21.00' }, { value: '40.00' }, { value: '97.00' }];
created() {
// Applies style formatting before inserting the column
this.spreadsheetObj!.cellFormat({ fontWeight: 'bold', textAlign: 'center' }, 'A2:G2');
// inserting a empty column at 0th index
this.spreadsheetObj!.insertColumn();
// inserting 1 column at the 5th index with column model
this.spreadsheetObj!.insertColumn([{ index: 5, width: 90 }]);
let rowIndex = 1;
// Updating the 5th column data
this.cellsModel.forEach((cell: CellModel): void => {
this.spreadsheetObj!.updateCell(cell, getCellAddress(rowIndex, 5)); rowIndex++;
});
// Applies style formatting after the columns are inserted
this.spreadsheetObj!.cellFormat({ textAlign: 'center' }, 'B3:B12');
this.spreadsheetObj!.cellFormat({ textAlign: 'center' }, 'D3:D12');
this.spreadsheetObj!.cellFormat({ textAlign: 'center' }, 'F3:H12');
}
}
import { bootstrapApplication } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import 'zone.js';
bootstrapApplication(AppComponent).catch((err) => console.error(err));
Delete
Delete support provides an option for deleting the rows and columns in the spreadsheet. Use allowDelete
property to enable or disable the delete option in Spreadsheet.
The rows and columns can be deleted dynamically in the following ways,
- Using
delete
method, you can delete the loaded rows and columns. - Using context menu, you can delete the selected rows and columns.
The following code example shows the delete operation of rows and columns in the spreadsheet.
import { NgModule } from '@angular/core'
import { BrowserModule } from '@angular/platform-browser'
import { SpreadsheetAllModule } from '@syncfusion/ej2-angular-spreadsheet'
import { Component, ViewChild } from '@angular/core';
import { SpreadsheetComponent } from '@syncfusion/ej2-angular-spreadsheet';
import { dataSource } from './datasource';
@Component({
imports: [
SpreadsheetAllModule
],
standalone: true,
selector: 'app-container',
template: `<ejs-spreadsheet #spreadsheet (created)="created()" [showFormulaBar]="false" [allowDelete]="true"
[showRibbon]="false">
<e-sheets>
<e-sheet name="Sheet1">
<e-ranges>
<e-range [dataSource]="data"></e-range>
</e-ranges>
<e-columns>
<e-column [width]=90></e-column>
<e-column [width]=220></e-column>
<e-column [width]=90></e-column>
<e-column [width]=140></e-column>
<e-column [width]=90></e-column>
<e-column [width]=100></e-column>
<e-column [width]=100></e-column>
</e-columns>
</e-sheet>
<e-sheet name="Sheet2">
<e-ranges>
<e-range [dataSource]="data"></e-range>
</e-ranges>
<e-columns>
<e-column [width]=90></e-column>
<e-column [width]=220></e-column>
<e-column [width]=90></e-column>
<e-column [width]=140></e-column>
<e-column [width]=90></e-column>
<e-column [width]=100></e-column>
<e-column [width]=100></e-column>
</e-columns>
</e-sheet>
</e-sheets>
</ejs-spreadsheet>`
})
export class AppComponent {
@ViewChild('spreadsheet')
spreadsheetObj: SpreadsheetComponent | undefined;
data: object[] = dataSource;
created() {
this.spreadsheetObj!.cellFormat({ fontWeight: 'bold', textAlign: 'center' }, 'A1:H1');
// deleting the rows from 8th to 10th index. To delete row, the third argument of enum type is passed as 'Row', the last argument specifies the sheet name or index in which the delete operation will perform. By default,active sheet will be considered. It is applicable only for model type Row and Column.
this.spreadsheetObj!.delete(8, 10, 'Row', 0); // startIndex, endIndex, Row, sheet index
// deleting the 2nd and 5th indexed columns
this.spreadsheetObj!.delete(2, 2, 'Column', 'Sheet2');
this.spreadsheetObj!.delete(5, 5, 'Column');
this.spreadsheetObj!.delete(0, 0, "Sheet"); // delete the first sheet. sheet index starts from 0
// Applies style formatting after deleted the rows and columns
this.spreadsheetObj!.cellFormat({ textAlign: 'center' }, 'A2:A8');
this.spreadsheetObj!.cellFormat({ textAlign: 'center' }, 'D2:G8');
}
}
import { bootstrapApplication } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import 'zone.js';
bootstrapApplication(AppComponent).catch((err) => console.error(err));
Limitations
The following features have some limitations in Insert/Delete:
- Insert row/column between the formatting applied cells.
- Insert row/column between the data validation.
- Insert row/column between the conditional formatting applied cells.
- Insert/delete row/column between the filter applied cells.
Hide and show
You can show or hide the rows and columns in the spreadsheet through property binding, method, and context menu.
Row
The rows can be hidden or shown through the following ways,
- Using
hidden
property in row, you can hide/show the rows at initial load. - Using
hideRow
method, you can hide the rows by specifying the start and end row index, set the last argumenthide
asfalse
to unhide the hidden rows. - Right-click on the row header and select the desired option from context menu
Column
The columns can be hidden or shown through following ways,
- Using
hidden
property in columns, you can hide/show the columns at initial load. - Using
hideColumn
method, you can hide the columns by specifying the start and end column index, set the last argumenthide
asfalse
to unhide the hidden columns. - Right-click on the column header and select the desired option from context menu
The following code example shows the hide/show rows and columns operation in the spreadsheet.
import { NgModule } from '@angular/core'
import { BrowserModule } from '@angular/platform-browser'
import { SpreadsheetAllModule } from '@syncfusion/ej2-angular-spreadsheet'
import { Component, ViewChild } from '@angular/core';
import { SpreadsheetComponent } from '@syncfusion/ej2-angular-spreadsheet';
import { dataSource } from './datasource';
@Component({
imports: [
SpreadsheetAllModule
],
standalone: true,
selector: 'app-container',
template: `<ejs-spreadsheet #spreadsheet (created)="created()" [showFormulaBar]="false"
[showSheetTabs]="false" [showRibbon]="false">
<e-sheets>
<e-sheet>
<e-ranges>
<e-range [dataSource]="data"></e-range>
</e-ranges>
<e-columns>
<e-column [width]=150></e-column>
<!-- Hiding the 1st and 2nd column index through property binding -->
<e-column [width]=100 [hidden]="true"></e-column>
<e-column [width]=100 [hidden]="true"></e-column>
<e-column [width]=80></e-column>
<e-column [width]=80></e-column>
<e-column [width]=80></e-column>
<e-column [width]=80></e-column>
<e-column [width]=80></e-column>
</e-columns>
<e-rows>
<e-row [index]=2 [hidden]="true"></e-row>
<e-row [hidden]="true"></e-row>
</e-rows>
</e-sheet>
</e-sheets>
</ejs-spreadsheet>`
})
export class AppComponent {
@ViewChild('spreadsheet')
spreadsheetObj: SpreadsheetComponent | undefined;
data: object[] = dataSource;
created() {
this.spreadsheetObj!.cellFormat({ fontWeight: 'bold', textAlign: 'center' }, 'A1:H1');
// Unhide the 2nd index hidden column
this.spreadsheetObj!.hideColumn(1, 1, false);
// Unhide the 3rd index hidden row
this.spreadsheetObj!.hideRow(3, 3, false);
// Hiding the 6th index column
this.spreadsheetObj!.hideColumn(6);
// Hiding the 8th and 9th index row
this.spreadsheetObj!.hideRow(8, 9);
this.spreadsheetObj!.cellFormat({ textAlign: 'center' }, 'D2:H11');
}
}
import { bootstrapApplication } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import 'zone.js';
bootstrapApplication(AppComponent).catch((err) => console.error(err));
Changing text in column headers
Using the beforeCellRender
event, you can change the text in the column headers. In that event, you can use the e-header-cell
class to identify the header cell element and update its text value.
The following code example shows how to change the text in the column headers.
import { NgModule } from '@angular/core'
import { BrowserModule } from '@angular/platform-browser'
import { SpreadsheetAllModule } from '@syncfusion/ej2-angular-spreadsheet'
import { Component, ViewChild } from '@angular/core';
import { SpreadsheetComponent, CellRenderEventArgs } from '@syncfusion/ej2-angular-spreadsheet';
@Component({
imports: [
SpreadsheetAllModule
],
standalone: true,
selector: 'app-container',
template: `<ejs-spreadsheet #spreadsheet (beforeCellRender)="beforeCellRender($event)"></ejs-spreadsheet>`
})
export class AppComponent {
@ViewChild('spreadsheet')
spreadsheetObj: SpreadsheetComponent | undefined;
beforeCellRender(args: CellRenderEventArgs) {
// Condition to check whether the rendered element is header cell.
if (
args.colIndex >= 0 &&
args.colIndex <= 10 &&
args.element.classList.contains('e-header-cell')
) {
let text = 'custom header ' + args.colIndex.toString();
// Add the custom text to the innerText of the element.
args.element.innerText = text;
}
}
}
import { bootstrapApplication } from '@angular/platform-browser';
import { AppComponent } from './app.component';
import 'zone.js';
bootstrapApplication(AppComponent).catch((err) => console.error(err));
Note
You can refer to our Angular Spreadsheet feature tour page for its groundbreaking feature representations. You can also explore our Angular Spreadsheet example to knows how to present and manipulate data.