Angular DataGrid Methods
This section describes the methods that can be used to manipulate the DataGrid UI component.
See Also
addColumn(columnOptions)
Adds a new column.
The column's configuration or the data field for which the column should be created.
This method is intended to add columns at runtime. To add columns at design-time, use the columns array.
If stateStoring is enabled, the added column is saved in the UI component's state after the creation.
- Do not call this method to unhide a hidden column. Modify the hidden column's visible property instead.
- addColumn() does not update the component's columns[] array.
See Also
addRow()
Adds an empty data row and switches it to the editing state.
Use this method if you want to add an empty row. If you need to add a row with data, do the following:
- For a remote data source, insert a new row with data into it and reload the data source: - jQueryJavaScript- $(function(){ var dataGrid = $("#gridContainer").dxDataGrid({ // ... }).dxDataGrid("instance"); var dataSource = dataGrid.getDataSource(); dataSource.store().insert(data).then(function() { dataSource.reload(); }) });- Angularapp.component.tsapp.module.ts- import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { constructor() { this.dataSource = new DataSource({ // ... }) } // ... insertRowRemote: function(dataObj) { this.dataSource.store().insert(dataObj).then(function() { this.dataSource.reload(); }) } }- import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxDataGridModule } from 'devextreme-angular'; @NgModule({ declarations: [ AppComponent ], imports: [ BrowserModule, DxDataGridModule ], bootstrap: [AppComponent] }) export class AppModule { }- VueApp.vue- <template> <DxDataGrid :data-source="dataSource" /> </template> <script> import 'devextreme/dist/css/dx.light.css'; import DxDataGrid from 'devextreme-vue/data-grid'; import DataSource from 'devextreme/data/data_source'; const ds = new DataSource({ // ... }); export default { components: { DxDataGrid }, data() { return { dataSource: ds } }, methods: { insertRowRemote: function(dataObj) { ds.store().insert(dataObj).then(() => ds.reload()); } } } </script>- ReactApp.js- import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import DataGrid from 'devextreme-react/data-grid'; import DataSource from 'devextreme/data/data_source'; const ds = new DataSource({ // ... }); class App extends React.Component { insertRowRemote(dataObj) { ds.store().insert(dataObj).then(() => ds.reload()); } render() { return ( <DataGrid dataSource={ds} /> ); } } export default App;
- For a local data source, push a new row into it. - jQueryJavaScript- $(function(){ var dataGrid = $("#gridContainer").dxDataGrid({ // ... }).dxDataGrid("instance"); var dataSource = dataGrid.getDataSource(); dataSource.store().push([ { type: "insert", data: data } ]) });- Angularapp.component.tsapp.module.ts- import { Component } from '@angular/core'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { constructor() { this.dataSource = new DataSource({ // ... }) } // ... insertRowLocal: function(dataObj) { this.dataSource.store().push([ { type: "insert", data: dataObj } ]) } }- import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxDataGridModule } from 'devextreme-angular'; @NgModule({ declarations: [ AppComponent ], imports: [ BrowserModule, DxDataGridModule ], bootstrap: [AppComponent] }) export class AppModule { }- VueApp.vue- <template> <DxDataGrid :data-source="dataSource" /> </template> <script> import 'devextreme/dist/css/dx.light.css'; import DxDataGrid from 'devextreme-vue/data-grid'; import DataSource from 'devextreme/data/data_source'; const ds = new DataSource({ // ... }); export default { components: { DxDataGrid }, data() { return { dataSource: ds } }, methods: { insertRowLocal: function(dataObj) { ds.store().push([ { type: "insert", data: dataObj } ]); } } } </script>- ReactApp.js- import React from 'react'; import 'devextreme/dist/css/dx.light.css'; import DataGrid from 'devextreme-react/data-grid'; import DataSource from 'devextreme/data/data_source'; const ds = new DataSource({ // ... }); class App extends React.Component { insertRowLocal(dataObj) { ds.store().push([ { type: "insert", data: dataObj } ]); } render() { return ( <DataGrid dataSource={ds} /> ); } } export default App;
This method works only when paging.enabled is false or when dataSource.reshapeOnPush is true and remoteOperations is false
See Also
- editing.allowUpdating
beginCustomLoading(messageText)
Shows the load panel.
The text for the load panel to display.
Normally, the load panel is invoked automatically while the UI component is busy rendering or loading data. Additionally, you can invoke it by calling this method. If you call it without the argument, the load panel displays text specified by the loadPanel.text property. To specify the appearance of the load panel, use the loadPanel object. Once invoked from code, the load panel will not hide until you call the endCustomLoading() method.
See Also
beginUpdate()
Postpones rendering that can negatively affect performance until the endUpdate() method is called.
The beginUpdate() and endUpdate() methods reduce the number of renders in cases where extra rendering can negatively affect performance.
See Also
byKey(key)
Gets a data object with a specific key.
A Promise that is resolved after the data object is loaded. It is a native Promise or a jQuery.Promise when you use jQuery.
The following code shows how to get a data object whose key is 15.
jQuery
widgetInstance.byKey(15).done(function(dataObject) {
        // process "dataObject"
    }).fail(function(error) {
        // handle error
    });See Also
cellValue(rowIndex, dataField)
Gets the value of a cell with a specific row index and a data field, column caption or name.
The index of the row to which the cell belongs. Refer to Column and Row Indexes for more information.
The data field, caption, or unique name of the column to which the cell belongs.
The cell's value.
cellValue(rowIndex, dataField, value)
Sets a new value to a cell with a specific row index and a data field, column caption or name.
The index of the row to which the cell belongs. Refer to Column and Row Indexes for more information.
The data field, caption, or unique name of the column to which the cell belongs.
The cell's new value.
DataGrid re-renders the entire row or edit form after the cellValue method changes a cell value. To re-render only the modified cell or form item editor, enable repaintChangesOnly.
Call saveEditData() after this method to save the changes:
jQuery
var dataGrid = $("#dataGridContainer").dxDataGrid("instance");
dataGrid.cellValue(0, "Position", "CEO");
dataGrid.saveEditData();Angular
import { ..., ViewChild } from "@angular/core";
import { DxDataGridModule, DxDataGridComponent } from "devextreme-angular";
// ...
export class AppComponent {
    @ViewChild(DxDataGridComponent, { static: false }) dataGrid: DxDataGridComponent;
    // Prior to Angular 8
    // @ViewChild(DxDataGridComponent) dataGrid: DxDataGridComponent;
    updateCell(rowIndex, dataField, value) {
        this.dataGrid.instance.cellValue(rowIndex, dataField, value);
        this.dataGrid.instance.saveEditData();
    }
}
@NgModule({
    imports: [
        // ...
        DxDataGridModule
    ],
    // ...
})Vue
<template>
    <DxDataGrid ...
        :ref="dataGridRefKey"> 
    </DxDataGrid>
</template>
<script>
import 'devextreme/dist/css/dx.light.css';
import { DxDataGrid } from 'devextreme-vue/data-grid';
const dataGridRefKey = 'my-data-grid';
export default {
    components: {
        DxDataGrid
    },
    data() {
        return {
            dataGridRefKey
        };
    },
    methods: {
        updateCell(rowIndex, dataField, value) {
            this.dataGrid.cellValue(rowIndex, dataField, value);
            this.dataGrid.saveEditData();
        }
    },
    computed: {
        dataGrid: function() {
            return this.$refs[dataGridRefKey].instance;
        }
    }
}
</script>React
import React, { useRef } from 'react';
import 'devextreme/dist/css/dx.light.css';
import DataGrid from 'devextreme-react/data-grid';
export default function App() {
    const dataGrid = useRef(null);
    const updateCell = (rowIndex, dataField, value) => {
        dataGrid.current.instance().cellValue(rowIndex, dataField, value);
        dataGrid.current.instance().saveEditData();
    };
    return (
        <DataGrid ...
            ref={dataGrid}>
        </DataGrid>
    );
}See Also
cellValue(rowIndex, visibleColumnIndex)
Gets the value of a cell with specific row and column indexes.
The index of the row to which the cell belongs. Refer to Column and Row Indexes for more information.
The visible index of the column to which the cell belongs.
The cell's value.
See Also
cellValue(rowIndex, visibleColumnIndex, value)
Sets a new value to a cell with specific row and column indexes.
The index of the row to which the cell belongs. Refer to Column and Row Indexes for more information.
The visible index of the column to which the cell belongs.
The cell's new value.
Call saveEditData() after this method to save the changes:
jQuery
var dataGrid = $("#dataGridContainer").dxDataGrid("instance");
dataGrid.cellValue(0, 1, "newValue");
dataGrid.saveEditData();Angular
import { ..., ViewChild } from "@angular/core";
import { DxDataGridModule, DxDataGridComponent } from "devextreme-angular";
// ...
export class AppComponent {
    @ViewChild(DxDataGridComponent, { static: false }) dataGrid: DxDataGridComponent;
    // Prior to Angular 8
    // @ViewChild(DxDataGridComponent) dataGrid: DxDataGridComponent;
    updateCell(rowIndex, columnIndex, value) {
        this.dataGrid.instance.cellValue(rowIndex, columnIndex, value);
        this.dataGrid.instance.saveEditData();
    }
}
@NgModule({
    imports: [
        // ...
        DxDataGridModule
    ],
    // ...
})Vue
<template>
    <DxDataGrid ...
        :ref="dataGridRefKey"> 
    </DxDataGrid>
</template>
<script>
import 'devextreme/dist/css/dx.light.css';
import { DxDataGrid } from 'devextreme-vue/data-grid';
const dataGridRefKey = 'my-data-grid';
export default {
    components: {
        DxDataGrid
    },
    data() {
        return {
            dataGridRefKey
        };
    },
    methods: {
        updateCell(rowIndex, columnIndex, value) {
            this.dataGrid.cellValue(rowIndex, columnIndex, value);
            this.dataGrid.saveEditData();
        }
    },
    computed: {
        dataGrid: function() {
            return this.$refs[dataGridRefKey].instance;
        }
    }
}
</script>React
import React, { useRef } from 'react';
import 'devextreme/dist/css/dx.light.css';
import DataGrid from 'devextreme-react/data-grid';
export default function App() {
    const dataGrid = useRef(null);
    const updateCell = (rowIndex, columnIndex, value) => {
        dataGrid.current.instance().cellValue(rowIndex, columnIndex, value);
        dataGrid.current.instance().saveEditData();
    };
    return (
        <DataGrid ...
            ref={dataGrid}>
        </DataGrid>
    );
}See Also
clearFilter(filterName)
Clears all row filters of a specific type.
The filter type.
The method's parameter specifies what type of filter should be cleared. This parameter can have one of the following values:
- "row"
 Clears the filter row.
- "header"
 Clears the header filter.
- "filterValue"
 Clears the filter builder and the synchronized filtering UI elements.
- "search"
 Clears the search panel.
- "dataSource"
 Clears the data source filter defined in the configuration or applied by the filter(filterExpr) method.
See Also
clearGrouping()
Ungroups grid records.
For more information about grouping, see the Grouping topic.
See Also
closeEditCell()
Switches the cell being edited back to the normal state. Takes effect only if editing.mode is batch or cell and showEditorAlways is false.
See Also
collapseAdaptiveDetailRow()
Collapses the currently expanded adaptive detail row (if there is one).
See Also
collapseAll(groupIndex)
Collapses master rows or groups of a specific level.
The group's level. Pass undefined to collapse all groups. Pass -1 to collapse all master rows.
See Also
collapseRow(key)
Collapses a group or a master row with a specific key.
The key of the group or the master row.
A Promise that is resolved after the row is collapsed. It is a native Promise or a jQuery.Promise when you use jQuery.
To collapse a group row, call this method with an array each member of which is a grouping value. To collapse a master row, pass its key to this method.
See Also
columnCount()
Gets the data column count. Includes visible and hidden columns, excludes command columns.
The data column count.
See Also
columnOption(id)
Gets all properties of a column with a specific identifier.
The column's properties.
This method gets the properties of the first column found by either of the below:
- Name 
 The unique name of the column.
- Column Index 
 The index of the column in the columns array.
- Data Field 
 The name of the data source field assigned to the column.
- Caption 
 The text displayed in the column header.
- Service String 
 A string that matches the following format: "optionName:value", where optionName is one of the column properties. For example, the following string corresponds to the command column:- "type:buttons".
See Also
columnOption(id, optionName)
Gets the value of a single column property.
The column's index, data field, caption, type, or unique name. Refer to columnOption(id) for details.
The property's name.
The property's value.
columnOption(id, optionName, optionValue)
Updates the value of a single column property.
The column's index, data field, caption, type, or unique name. Refer to columnOption(id) for details.
The property's name.
The property's new value.
columnOption(id, options)
Updates the values of several column properties.
The column's index, data field, caption, type, or unique name. Refer to columnOption(id) for details.
The properties with their new values.
defaultOptions(rule)
Specifies the device-dependent default configuration properties for this component.
The component's default device properties.
| Name | Type | Description | 
|---|---|---|
| device | | | Device parameters. | 
| options | Options to be applied. | 
defaultOptions is a static method that the UI component class supports. The following code demonstrates how to specify default properties for all instances of the DataGrid UI component in an application executed on the desktop.
jQuery
DevExpress.ui.dxDataGrid.defaultOptions({ 
    device: { deviceType: "desktop" },
    options: {
        // Here go the DataGrid properties
    }
});Angular
import DataGrid, { Properties } from "devextreme/ui/data_grid";
// ...
export class AppComponent {
    constructor () {
        DataGrid.defaultOptions<Properties>({
            device: { deviceType: "desktop" },
            options: {
                // Here go the DataGrid properties
            }
        });
    }
}Vue
<template>
    <div>
        <DxDataGrid id="dataGrid1" />
        <DxDataGrid id="dataGrid2" />
    </div>
</template>
<script>
import DxDataGrid from "devextreme-vue/data-grid";
import DataGrid from "devextreme/ui/data_grid";
DataGrid.defaultOptions({
    device: { deviceType: "desktop" },
    options: {
        // Here go the DataGrid properties
    }
});
export default {
    components: {
        DxDataGrid
    }
}
</script>React
import dxDataGrid from "devextreme/ui/data_grid";
import DataGrid from "devextreme-react/data-grid";
dxDataGrid.defaultOptions({
    device: { deviceType: "desktop" },
    options: {
        // Here go the DataGrid properties
    }
});
export default function App() {
    return (
        <div>
            <DataGrid id="dataGrid1" />
            <DataGrid id="dataGrid2" />
        </div>
    )
}You can also set rules for multiple device types:
jQuery
const devicesConfig = [
    { deviceType: 'desktop' },
    { deviceType: 'tablet' },
    { deviceType: 'phone' },
];
devicesConfig.forEach(deviceConfig => {
    DevExpress.ui.dxDataGrid.defaultOptions({ 
        device: deviceConfig,
        options: {
            // Here go the DataGrid properties
        }
    });
});Angular
import DataGrid, { Properties } from "devextreme/ui/data_grid";
// ...
export class AppComponent {
    constructor () {
        const devicesConfig = [
            { deviceType: 'desktop' },
            { deviceType: 'tablet' },
            { deviceType: 'phone' },
        ];
        devicesConfig.forEach(deviceConfig => {
            DataGrid.defaultOptions<Properties>({
                device: deviceConfig,
                options: {
                    // Here go the DataGrid properties
                }
            });
        });
    }
}Vue
<template>
    <div>
        <DxDataGrid />
    </div>
</template>
<script>
import DxDataGrid from "devextreme-vue/data-grid";
import DataGrid from "devextreme/ui/data_grid";
const devicesConfig = [
    { deviceType: 'desktop' },
    { deviceType: 'tablet' },
    { deviceType: 'phone' },
];
devicesConfig.forEach(deviceConfig => {
    DataGrid.defaultOptions({
        device: deviceConfig,
        options: {
            // Here go the DataGrid properties
        }
    });
});
export default {
    components: {
        DxDataGrid
    }
}
</script>React
import dxDataGrid from "devextreme/ui/data_grid";
import DataGrid from "devextreme-react/data-grid";
const devicesConfig = [
    { deviceType: 'desktop' },
    { deviceType: 'tablet' },
    { deviceType: 'phone' },
];
devicesConfig.forEach(deviceConfig => {
    dxDataGrid.defaultOptions({
        device: deviceConfig,
        options: {
            // Here go the DataGrid properties
        }
    });
});
export default function App() {
    return (
        <div>
            <DataGrid />
        </div>
    )
}deleteColumn(id)
Removes a column.
This method removes the first column found by either of the below:
- Name 
 The unique name of the column.
- Column Index 
 The index of the column in the columns array.
- Data Field 
 The name of the data source field assigned to the column.
- Caption 
 The text displayed in the column header.
See Also
deleteRow(rowIndex)
Removes a row with a specific index.
The row's index. Refer to Column and Row Indexes for more information.
See Also
deselectAll()
Clears the selection of all rows on all pages or the currently rendered page only.
A Promise that is resolved after the selection is cleared. It is a native Promise or a jQuery.Promise when you use jQuery.
Depending on the value of the selectAllMode property, this method clears selection of all rows on all pages or on the currently rendered pages only. The selection is cleared of only those rows that meet filtering conditions if a filter is applied. To clear selection regardless of the selectAllMode property's value or applied filters, call the clearSelection() method.
See Also
deselectRows(keys)
Cancels the selection of rows with specific keys.
Array<any>
The row keys.
A Promise that is resolved after selection is cleared. It is a native Promise or a jQuery.Promise when you use jQuery.
See Also
dispose()
Disposes of all the resources allocated to the DataGrid instance.
jQuery
After calling this method, remove the DOM element associated with the UI component:
$("#myDataGrid").dxDataGrid("dispose");
$("#myDataGrid").remove();Angular
Use conditional rendering instead of this method:
<dx-data-grid ...
    *ngIf="condition">
</dx-data-grid>Vue
Use conditional rendering instead of this method:
<template>
    <DxDataGrid ...
        v-if="condition">
    </DxDataGrid>
</template>
<script>
import DxDataGrid from 'devextreme-vue/data-grid';
export default {
    components: {
        DxDataGrid
    }
}
</script>React
Use conditional rendering instead of this method:
import React from 'react';
import DataGrid from 'devextreme-react/data-grid';
function DxDataGrid(props) {
    if (!props.shouldRender) {
        return null;
    }
    return (
        <DataGrid ... >    
        </DataGrid>
    );
}
class App extends React.Component {
    render() {
        return (
            <DxDataGrid shouldRender="condition" />
        );
    }
}
export default App;editCell(rowIndex, dataField)
Switches a cell with a specific row index and a data field to the editing state. Takes effect only if the editing mode is "batch" or "cell".
The index of the row to which the cell belongs. Refer to Column and Row Indexes for more information.
The name of the data field in the data source.
editCell(rowIndex, visibleColumnIndex)
Switches a cell with specific row and column indexes to the editing state. Takes effect only if the editing mode is "batch" or "cell".
The index of the row to which the cell belongs. Refer to Column and Row Indexes for more information.
The visible index of the column to which the cell belongs.
editRow(rowIndex)
Switches a row with a specific index to the editing state. Takes effect only if the editing mode is "row", "popup" or "form".
The row's index. Refer to Column and Row Indexes for more information.
See Also
element()
Gets the root UI component element.
An HTML element or a jQuery element when you use jQuery.
See Also
endCustomLoading()
Hides the load panel.
Normally, the UI component hides the load panel automatically once data is ready. But if you have invoked the load panel from code using the beginCustomLoading(messageText) method, you must call the endCustomLoading() method to hide it.
See Also
endUpdate()
Refreshes the UI component after a call of the beginUpdate() method.
The beginUpdate() and endUpdate() methods reduce the number of renders in cases where extra rendering can negatively affect performance.
See Also
expandAdaptiveDetailRow(key)
Expands an adaptive detail row.
The key of the data row to which the adaptive detail row belongs.
To access a data row by its key, you should specify the field that provides keys in the data source. If no key was specified, the whole data object is considered the key.
See Also
expandAll(groupIndex)
Expands master rows or groups of a specific level. Does not apply if data is remote.
The group's level. Pass undefined to expand all groups. Pass -1 to expand all master rows.
See Also
expandRow(key)
Expands a group or a master row with a specific key.
The key of the group or the master row.
A Promise that is resolved after the row is expanded. It is a native Promise or a jQuery.Promise when you use jQuery.
To expand a group row, call this method with an array (each member of which is a grouping value). To expand a master row, pass its key to this method.
A group row can also be expanded when you navigate to a data row within it. See navigateToRow(key) for more information.
See Also
filter()
Gets a filter expression applied to the UI component's data source using the filter(filterExpr) method and the DataSource's filter property.
See Also
filter(filterExpr)
Applies a filter to the dataSource.
The filter passed to this method is not reflected in any of the filtering UI elements and is applied before these elements' filters. To change UI filters in code, use the following properties instead:
| Filtering UI Element | Property | 
|---|---|
| Filter Row | columns[].filterValue and columns[].selectedFilterOperation | 
| Header Filter | columns[].filterValues and columns[].filterType | 
| Intergrated Filter Builder | filterValue | 
| Search Panel | searchPanel.text | 
To clear all filters applied in code and the UI, call the clearFilter() method.
See Also
focus()
Sets focus on the UI component.
The focused DataGrid element depends on the following conditions:
| Condition | Focused element | 
|---|---|
| focusedRowEnabled is set to true. | Focuses the first DataGrid row. | 
| focusedRowEnabled is set to false. | Focuses the first cell in the data area. | 
| Grouping is configured. | Focuses the first group header. | 
See Also
getCellElement(rowIndex, dataField)
Gets a cell with a specific row index and a data field, column caption or name.
The index of the row to which the cell belongs. Refer to Column and Row Indexes for more information.
The data field, caption, or unique name of the column to which the cell belongs.
The cell's container. It is an HTML Element or a jQuery Element when you use jQuery.
If the specified row or data field does not exist, the method returns undefined.
See Also
getCellElement(rowIndex, visibleColumnIndex)
Gets a cell with specific row and column indexes.
The index of the row to which the cell belongs. Refer to Column and Row Indexes for more information.
The visible index of the column to which the cell belongs.
The cell's container. It is an HTML Element or a jQuery Element when you use jQuery.
If the specified row or column does not exist, the method returns undefined.
See Also
getCombinedFilter()
Gets the total filter that combines all the filters applied.
Use this method to get the total filter. This filter combines filters applied using filtering UI elements and the filter(filterExpr) method. Note that the total filter contains getters. To get the total filter containing data fields, call the getCombinedFilter(returnDataField) method.
See Also
getCombinedFilter(returnDataField)
Gets the total filter that combines all the filters applied.
Use this method to get the total filter that combines filters applied using filtering UI elements and the filter(filterExpr) method. getCombinedFilter(returnDataField) can return a filter expression that uses data fields instead of getters if you pass true to the returnDataField parameter. If you implement getters like columns[].calculateCellValue in your DataGrid, set returnDataField to false or utilize the getCombinedFilter() method.
For details on how to obtain all filtered and sorted rows of a DataGrid component with getCombinedFilter(returnDataField), refer to the following example:
For details on how to filter a Chart component's series based on a DataGrid component's filters with getCombinedFilter(returnDataField), refer to the following example:
See Also
getDataSource()
Gets the DataSource instance.
The DataSource instance.
See Also
getInstance(element)
Gets the instance of a UI component found using its DOM node.
The UI component's instance.
getInstance is a static method that the UI component class supports. The following code demonstrates how to get the DataGrid instance found in an element with the myDataGrid ID:
// Modular approach
import DataGrid from "devextreme/ui/data_grid";
...
let element = document.getElementById("myDataGrid");
let instance = DataGrid.getInstance(element) as DataGrid;
// Non-modular approach
let element = document.getElementById("myDataGrid");
let instance = DevExpress.ui.dxDataGrid.getInstance(element);See Also
getKeyByRowIndex(rowIndex)
Gets the key of a row with a specific index.
The row's visible index. Refer to Column and Row Indexes for more information.
The row's key; undefined if nothing found.
See Also
getRowElement(rowIndex)
Gets the container of a row with a specific index.
The row's visible index. Refer to Column and Row Indexes for more information.
See Also
getRowIndexByKey(key)
Gets the index of a row with a specific key.
The row's index; -1 if nothing found. Refer to Column and Row Indexes for more information.
See Also
getScrollable()
Gets the instance of the UI component's scrollable part.
Scrollable
The scrollable part's instance.
For information on API members of the scrollable part, refer to the ScrollView section. The list below shows ScrollView members that are unavailable for this method.
Properties:
- pullingDownText
- pulledDownText
- refreshingText
- reachBottomText
- onPullDown
- onReachBottom
Methods:
- release(preventScrollBottom)
- refresh()
See Also
getSelectedRowKeys()
Gets the currently selected rows' keys.
The whole data object is considered a key if the field providing keys is not specified in the data source. In this case, this method returns data objects, that is, operates like the getSelectedRowsData() method.
Note that when selection is deferred, the method returns a Promise (a native Promise or a jQuery.Promise when you use jQuery) that should be resolved with an array of keys.
See Also
getSelectedRowsData()
Gets the selected rows' data objects.
The selected rows' data objects.
The objects are not processed by the DataSource.
When selection is deferred, the method returns a Promise (a native Promise or a jQuery.Promise when you use jQuery) that is resolved with the selected rows' data objects.
jQuery
var dataGrid = $("#dataGridContainer").dxDataGrid("instance");
var selectedRowsData = dataGrid.getSelectedRowsData();
// ===== or when deferred selection is used =====
dataGrid.getSelectedRowsData().then(function(selectedRowsData) {
    // Your code goes here
});Angular
import { Component, ViewChild } from '@angular/core';
import { DxDataGridComponent } from 'devextreme-angular';
@Component({
    selector: 'app-root',
    templateUrl: './app.component.html',
    styleUrls: ['./app.component.css']
})
export class AppComponent {
    @ViewChild('dataGridRef', { static: false }) dataGrid: DxDataGridComponent;
    // Prior to Angular 8
    // @ViewChild('dataGridRef') dataGrid: DxDataGridComponent;
    selectedRowsData = [];
    getSelectedData() {
        this.selectedRowsData = this.dataGrid.instance.getSelectedRowsData();
        // ===== or when deferred selection is used =====
        this.dataGrid.instance.getSelectedRowsData().then((selectedRowsData) => {
            // Your code goes here
        });
    }
}
<dx-data-grid ...
    #dataGridRef
></dx-data-grid>
import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { AppComponent } from './app.component';
import { DxDataGridModule } from 'devextreme-angular';
@NgModule({
    declarations: [
        AppComponent
    ],
    imports: [
        BrowserModule,
        DxDataGridModule
    ],
    providers: [ ],
    bootstrap: [AppComponent]
})
export class AppModule { }Vue
<template>
    <DxDataGrid ...
        :ref="dataGridRef">
    </DxDataGrid>
</template>
<script>
import 'devextreme/dist/css/dx.light.css';
import DxDataGrid from 'devextreme-vue/data-grid';
const dataGridRef = 'dataGrid';
export default {
    components: {
        DxDataGrid
    },
    data() {
        return {
            dataGridRef,
            selectedRowsData: []
        }
    },
    computed: {
        dataGrid: function() {
            return this.$refs[dataGridRef].instance;
        }
    },
    methods: {
        getSelectedData() {
            this.selectedRowsData = this.dataGrid.getSelectedRowsData();
            // ===== or when deferred selection is used =====
            this.dataGrid.getSelectedRowsData().then((selectedRowsData) => {
                // Your code goes here
            });
        }
    }
}
</script>React
import React from 'react';
import 'devextreme/dist/css/dx.light.css';
import DataGrid from 'devextreme-react/data-grid';
class App extends React.Component {
    constructor(props) {
        super(props);
        this.dataGridRef = React.createRef();
        this.selectedRowsData = [];
        this.getSelectedData = () => {
            this.selectedRowsData = this.dataGrid.getSelectedRowsData();
            // ===== or when deferred selection is used =====
            this.dataGrid.getSelectedRowsData().then((selectedRowsData) => {
                // Your code goes here
            });
        }
    }
    get dataGrid() {
        return this.dataGridRef.current.instance();
    }
    render() {
        return (
            <DataGrid ...
                ref={this.dataGridRef}>
            </DataGrid>
        );
    }
}
export default App;ASP.NET MVC Controls
@(Html.DevExtreme().DataGrid()
    .ID("dataGrid")
    @* ... *@
)
<script type="text/javascript">
    function getSelectedData() {
        var dataGrid = $("#dataGrid").dxDataGrid("instance");
        var selectedRowsData = dataGrid.getSelectedRowsData();
        // ...
        // ===== or when deferred selection is used =====
        dataGrid.getSelectedRowsData().then(function(selectedRowsData) {
            // Your code goes here
        });
    }
</script>See Also
getTotalSummaryValue(summaryItemName)
Gets the value of a total summary item.
The total summary item's value.
See Also
getVisibleColumnIndex(id)
Gets the index of a visible column.
The column's index, data field, caption, type, or unique name. Refer to columnOption(id) for details.
The column's index.
getVisibleColumns()
Gets all visible columns.
Visible columns; may include command columns.
See Also
getVisibleColumns(headerLevel)
Gets all visible columns at a specific hierarchical level of column headers. Use it to access banded columns.
The column headers' level.
Visible columns; may include command columns.
See Also
hasEditData()
Checks whether the UI component has unsaved changes.
true if the UI component has unsaved changes; otherwise - false.
See Also
instance()
Gets the UI component's instance. Use it to access other methods of the UI component.
This UI component's instance.
See Also
isAdaptiveDetailRowExpanded(key)
Checks whether an adaptive detail row is expanded or collapsed.
The key of the data row to which the adaptive detail row belongs.
true if the adaptive detail row is expanded; false if collapsed.
To access a data row by its key, specify the field that provides keys in the data source. If no key was specified, the whole data object is considered the key.
See Also
isRowExpanded(key)
Checks whether a specific group or master row is expanded or collapsed.
The key of the group or master row.
true if the row is expanded; false if collapsed.
To check whether a group row is expanded, call this method with an array, in which each member is a grouping value. To check if a master row is expanded, pass its key to this method.
See Also
isRowFocused(key)
Checks whether a row with a specific key is focused.
A row's key.
true if the row is focused; otherwise false.
See Also
isRowSelected(data)
Checks whether a row found using its data object is selected. Takes effect only if selection.deferred is true.
The row's data object.
true if the row is selected; otherwise false.
See Also
isRowSelected(key)
Checks whether a row with a specific key is selected. Takes effect only if selection.deferred is false.
The row's key.
true if the row is selected; otherwise false.
See Also
keyOf(obj)
Gets a data object's key.
The data object.
The data object's key.
See Also
navigateToRow(key)
Navigates to a row with the specified key.
The row's key.
A Promise that is resolved after the grid is navigated to the specified row. It is a native Promise or a jQuery.Promise when you use jQuery.
This method performs the following actions:
- Switches the UI component to the data page that contains the specified row.
- Expands groups in which the row is nested (if rows are grouped and the groups are collapsed).
- Scrolls the UI component to display the row (if the row is outside the viewport).
The following requirements apply when you use this method:
- The UI component's keyExpr or the store's key property should be specified. 
- Rows should be initially sorted by keys. You can sort them on the server or use a column's sortOrder or the DataSource's sort property to sort the rows on the client. 
- Scrolling mode should not be "infinite". 
If you enable the remoteOperations property, the DataGrid generates additional requests with comparison operators (for example, < and >) to calculate the page number where a row with a focused key is located. This logic does not work if ODataStore is bound to a table with GUID keys. You need to set the autoNavigateToFocusedRow property to false or disable the remoteOperations property to ensure it operates correctly.
See Also
off(eventName)
Detaches all event handlers from a single event.
The event's name.
The object for which this method is called.
See Also
off(eventName, eventHandler)
Detaches a particular event handler from a single event.
The object for which this method is called.
See Also
on(eventName, eventHandler)
Subscribes to an event.
The object for which this method is called.
Use this method to subscribe to one of the events listed in the Events section.
See Also
on(events)
Subscribes to events.
Events with their handlers: { "eventName1": handler1, "eventName2": handler2, ...}
The object for which this method is called.
Use this method to subscribe to several events with one method call. Available events are listed in the Events section.
See Also
option(optionName)
Gets the value of a single property.
The property's name or full path.
This property's value.
See Also
option(options)
Updates the values of several properties.
Options with their new values.
See Also
pageCount()
Gets the total page count.
The total page count.
See Also
pageIndex()
Gets the current page index.
The current page index.
When the scrolling mode is "virtual" or "infinite", this method returns the index of the page whose row is shown first in the UI component.
See Also
pageIndex(newIndex)
Switches the UI component to a specific page using a zero-based index.
The zero-based page index.
A Promise that is resolved after the page is shown. It is a native Promise or a jQuery.Promise when you use jQuery.
See Also
refresh()
Reloads data and repaints data rows.
A Promise that is resolved after data is loaded. It is a native Promise or a jQuery.Promise when you use jQuery.
refresh() calls dataSource.reload() and refreshes component properties such as selection and lookup column dataSources. This method also repaints all data rows if repaintChangesOnly is false (default).
DataGrid cannot track data source changes applied outside of the component. To update the component in such cases, call the refresh() method.
The following code snippet shows how to call refresh():
jQuery
var dataGrid = $("#dataGridContainer").dxDataGrid("instance");
dataGrid.refresh()
    .done(function() {
        // ...
    })
    .fail(function(error) {
        // ...
    });Angular
<dx-data-grid #dataGridVar ... >
    <!-- ... -->
</dx-data-grid>
import { Component, ViewChild } from '@angular/core';
@Component({
    selector: 'app-root',
    templateUrl: './app.component.html',
    styleUrls: ['./app.component.css']
})
export class AppComponent {
    @ViewChild('dataGridVar', { static: false }) dataGrid: DxDataGridComponent;
    // Prior to Angular 8
    // @ViewChild('dataGridVar') dataGrid: DxDataGridComponent;
    refreshDataGrid() {
        this.dataGrid.instance.refresh()
            .then(function() {
                // ...
            })
            .catch(function(error) {
                // ...
            });
    }
}Vue
<template>
    <DxDataGrid ...
        :ref="dataGridRefKey">
        <!-- ... -->
    </DxDataGrid>
</template>
<script>
import 'devextreme/dist/css/dx.light.css';
import { DxDataGrid, /* ... */ } from 'devextreme-vue/data-grid';
const dataGridRefKey = 'my-data-grid';
export default {
    components: {
        DxDataGrid,
        // ...
    },
    data() {
        return {
            dataGridRefKey
        };
    },
    computed: {
        dataGrid: function() {
            return this.$refs[dataGridRefKey].instance;
        }
    },
    methods: {
        refreshDataGrid() {
            this.dataGrid.refresh()
                .then(function() {
                    // ...
                })
                .catch(function(error) {
                    // ...
                });
        }
    }
};
</script>React
import React from 'react';
import 'devextreme/dist/css/dx.light.css';
import { DataGrid, /* ... */ } from 'devextreme-react/data-grid';
class App extends React.Component {
    render() {
        return (
            <DataGrid ...
                ref={ref => this.dataGrid = ref}>
                {/* ... */}
            </DataGrid>
        );
    }
    refreshDataGrid() {
        this.dataGrid.instance.refresh()
            .then(function() {
                // ...
            })
            .catch(function(error) {
                // ...
            });
    }
}
export default App;ASP.NET MVC Controls
@(Html.DevExtreme().DataGrid()
    .ID("dataGridContainer")
    // ...
)
<script type="text/javascript">
    function refreshDataGrid() {
        var dataGrid = $("#dataGridContainer").dxDataGrid("instance");
        dataGrid.refresh()
            .done(function() {
                // ...
            })
            .fail(function(error) {
                // ...
            });
    }
</script>- Calling the refresh() method in edit mode discards unsaved changes and cancels the edit mode. When editing.mode is "batch", the component cancels the edit mode but does not discard unsaved changes.
- refresh() does not repaint the editing popup when editing.mode is "popup".
- The component may reject the refresh promise if DataGrid accesses its dataSource while the promise is in progress. To avoid rejecting the refresh promise, modify properties that initiate data queries after refresh is completed.
See Also
refresh(changesOnly)
Reloads data and repaints all or only updated data rows.
Pass true to repaint updated data rows; false to repaint all data rows.
A Promise that is resolved after data is loaded. It is a native Promise or a jQuery.Promise when you use jQuery.
repaint()
Renders the component again without reloading data. Use the method to update the component's markup and appearance dynamically.
The repaint() method re-initializes the component with new settings, resetting its state and history. 
See Also
- reload() in DataSource | List
- refresh() in DataGrid | TreeList
repaintRows(rowIndexes)
Repaints specific rows.
Row indexes. Refer to Column and Row Indexes for more information.
This method updates the row objects and their visual representation.
See Also
resetOption(optionName)
Resets a property to its default value.
A property's name.
See Also
saveEditData()
Saves changes that a user made to data.
A Promise that is resolved after changes are saved in the data source. It is a native Promise or a jQuery.Promise when you use jQuery.
See Also
searchByText(text)
Seeks a search string in the columns whose allowSearch property is true.
A search string. Pass an empty string to clear search results.
See Also
selectAll()
Selects all rows.
A Promise that is resolved after all rows are selected. It is a native Promise or a jQuery.Promise when you use jQuery.
Depending on the value of the selectAllMode property, this method selects all rows on all pages or on the currently rendered pages only. If a filter is applied, this method selects only those rows that meet the filtering conditions.
See Also
selectRows(keys, preserve)
Selects rows with specific keys.
A Promise that is resolved after the rows are selected. It is a native Promise or a jQuery.Promise when you use jQuery.
By default, this method call clears selection of previously selected rows. To keep these rows selected, call this method with true as the second argument.
widgetInstance.selectRows([5, 10, 12], true);
If you specify DataGrid's key as composite (for example, key: ['id', 'name']), you need to call this method as follows:
widgetInstance.selectRows([ { id: 5, name: 'Alex' }, { id: 10: name: 'Bob' } ], true);See Also
selectRowsByIndexes(indexes)
Selects rows with specific indexes.
A Promise that is resolved after the rows are selected. It is a native Promise or a jQuery.Promise when you use jQuery.
This method has the following specifics:
- This method call clears selection of all previously selected rows.
- When calculating row indexes, the UI component counts data and group rows. Nevertheless, only data rows can be selected.
- If the pager is used, selection is cleared once a user moves to a different page. To preserve it, call this method within the onContentReady handler.
See Also
showColumnChooser()
Shows the column chooser.
If the following conditions are met:
- You use state storing. 
- columnChooser.enabled is set to - false(default).
- You call this method. 
Then, column chooser may not update data. To fix this issue, assign true to the columnChooser.enabled property. If you still want to hide the default column chooser icon, use the toolbar option.
See Also
state()
Gets the current UI component state.
The current UI component state.
The following example shows how to save the UI component state in the local storage and load it from there:
jQuery
$(function () {
    const dataGrid = $("#dataGridContainer").dxDataGrid({ 
        // ...
    }).dxDataGrid("instance");
    $("#save").dxButton({
        text: "Save State",
        onClick: function() {
            const state = dataGrid.state();
            // Saves the state in the local storage
            localStorage.setItem("dataGridState", JSON.stringify(state));
        }
    });
    $("#load").dxButton({
        text: "Load State",
        onClick: function() {
            const state = JSON.parse(localStorage.getItem("dataGridState"));
            dataGrid.state(state);
        }
    });
});Angular
import { Component, ViewChild } from "@angular/core";
import { 
    DxDataGridModule, 
    DxButtonModule, 
    DxDataGridComponent 
} from "devextreme-angular";
// ...
export class AppComponent {
    @ViewChild(DxDataGridComponent, { static: false }) dataGrid: DxDataGridComponent
    // Prior to Angular 8
    // @ViewChild(DxDataGridComponent) dataGrid: DxDataGridComponent
    saveState() {
        const state = this.dataGrid.instance.state();
        // Saves the state in the local storage
        localStorage.setItem("dataGridState", JSON.stringify(state));
    }
    loadState() {
        const state = JSON.parse(localStorage.getItem("dataGridState"));
        this.dataGrid.instance.state(state);
    }
}
@NgModule({
    imports: [
        DxDataGridModule,
        DxButtonModule,
        // ...
    ],
    // ...
})
<dx-data-grid ...>
</dx-data-grid>
<dx-button
    text="Save State"
    (onClick)="saveState()">
</dx-button>
<dx-button
    text="Load State"
    (onClick)="loadState()">
</dx-button>Vue
<template>
    <DxDataGrid ...
        :ref="dataGridRefKey">
    </DxDataGrid>
    <DxButton
        text="Save State"
        @click="saveState"
    />
    <DxButton
        text="Load State"
        @click="loadState"
    />
</template>
<script>
import 'devextreme/dist/css/dx.light.css';
import DxDataGrid, {
    // ...
} from 'devextreme-vue/data-grid';
import DxButton from 'devextreme-vue/button';
const dataGridRefKey = "my-data-grid";
export default {
    components: {
        DxDataGrid,
        // ...
        DxButton
    },
    data() {
        return {
            dataGridRefKey
        }
    },
    methods: {
        saveState() {
            const state = this.dataGrid.state();
            // Saves the state in the local storage
            localStorage.setItem("dataGridState", JSON.stringify(state));
        },
        loadState() {
            const state = JSON.parse(localStorage.getItem("dataGridState"));
            this.dataGrid.state(state);
        }
    },
    computed: {
        dataGrid: function() {
            return this.$refs[dataGridRefKey].instance;
        }
    }
}
</script>React
import React, { useRef } from 'react';
import 'devextreme/dist/css/dx.light.css';
import DataGrid, {
    // ...
} from 'devextreme-react/data-grid';
import Button from 'devextreme-react/button';
export default function App() {
    const dataGrid = useRef(null);
    const saveState = () => {
        const state = dataGrid.current.instance().state();
        // Saves the state in the local storage
        localStorage.setItem("dataGridState", JSON.stringify(state));
    };
    const loadState = () => {
        const state = JSON.parse(localStorage.getItem("dataGridState"));
        dataGrid.current.instance().state(state);
    };
    return (
        <React.Fragment>
            <DataGrid ...
                ref={dataGrid}>
            </DataGrid>
            <Button
                text="Save State"
                onClick={saveState}
            />
            <Button
                text="Load State"
                onClick={loadState}
            />
        </React.Fragment>
    );
}See Also
state(state)
Sets the UI component state.
The UI component's state to be set. The state object will override the current state.
After the state is set, the DataGrid reloads data to apply sorting, filtering, and other data processing settings.
Refer to the state() method description for an example of how to work with the UI component state.
See Also
totalCount()
Gets the total row count.
The total row count.
jQuery
$(() => {
    const dataSource = new DevExpress.data.DataSource({
        store: customers,
        paginate: true
    });
    $('#gridContainer').dxDataGrid({
        dataSource,
        paging: {
            enabled: true
        },
        // ...
        onContentReady (e) {
            const totalCount = e.component.totalCount();
            // ...
        }
    });
});Angular
import { Component } from '@angular/core';
import DataSource from "devextreme/data/data_source";
@Component({
    selector: 'app-root',
    templateUrl: './app.component.html',
    styleUrls: ['./app.component.css']
})
export class AppComponent {
    totalCount: Number;
    dataSource: DataSource;
    constructor () {
        this.dataSource = new DataSource({
            store: customers,
            paginate: true
        });
    }
    getTotalCount(e) {
        this.totalCount = e.component.totalCount();
        // ...
    }
}
<dx-data-grid ...
    [dataSource]="dataSource"
    (onContentReady)="getTotalCount($event)"
>
    <dxo-paging [enabled]="true"> </dxo-paging>
</dx-data-grid>Vue
<template>
    <DxDataGrid ...
        :data-source="dataSource"
        @content-ready="getTotalCount"
    >
        <DxPaging :enabled="true" />
    </DxDataGrid>
</template>
<script>
import DxDataGrid, { DxPaging } from 'devextreme-vue/data-grid';
import DataSource from 'devextreme/data/data_source';
const dataSource = new DataSource({
    store: customers,
    paginate: true
});
export default {
    components: {
        DxDataGrid,
        DxPaging
    },
    data() {
        return {
            dataSource,
            totalCount
        }
    },
    methods: {
        getTotalCount(e) {
            this.totalCount = e.component.totalCount();
            // ...
        }
    }
}
</script>React
import React from 'react';
import DataGrid, { Paging } from 'devextreme-react/data-grid';
import DataSource from 'devextreme/data/data_source';
const dataSource = new DataSource({
    store: customers,
    paginate: true
});
const getTotalCount = (e) => {
    const totalCount = e.component.totalCount();
    // ...
}
function App() {
    return (
        <DataGrid ...
            dataSource={dataSource}
            onContentReady={getTotalCount}
        >
            <Paging enabled={true} />
        </DataGrid>
    );
}
export default App;- If a filter is applied, totalCount() returns the number of records after filtering. 
- If scrolling.mode is "infinite", this method returns the number of loaded rows. 
- If paging is disabled in the DataGrid (paging.enabled is false) or underlying DataSource (paginate is false), totalCount() returns -1. To get the total record count in this case, use the following code: - jQueryindex.js- const dataGrid = $("#dataGridContainer").dxDataGrid("instance"); const dataSource = dataGrid.getDataSource(); const recordCount = dataSource.items().length;- Angularapp.component.tsapp.component.htmlapp.module.ts- import { Component, ViewChild } from '@angular/core'; import { DxDataGridComponent } from 'devextreme-angular'; @Component({ selector: 'app-root', templateUrl: './app.component.html', styleUrls: ['./app.component.css'] }) export class AppComponent { @ViewChild('dataGridRef', { static: false }) dataGrid: DxDataGridComponent; // Prior to Angular 8 // @ViewChild('dataGridRef') dataGrid: DxDataGridComponent; getRecordCount() { const dataSource = this.dataGrid.instance.getDataSource(); return dataSource.items().length; } }- <dx-data-grid ... #dataGridRef ></dx-data-grid>- import { BrowserModule } from '@angular/platform-browser'; import { NgModule } from '@angular/core'; import { AppComponent } from './app.component'; import { DxDataGridModule } from 'devextreme-angular'; @NgModule({ declarations: [ AppComponent ], imports: [ BrowserModule, DxDataGridModule ], providers: [ ], bootstrap: [AppComponent] }) export class AppModule { }- VueApp.vue- <template> <DxDataGrid ... :ref="dataGridRef"> </DxDataGrid> </template> <script> import 'devextreme/dist/css/dx.light.css'; import DxDataGrid from 'devextreme-vue/data-grid'; const dataGridRef = 'dataGrid'; export default { components: { DxDataGrid }, data() { return { dataGridRef } }, computed: { dataGrid: function() { return this.$refs[dataGridRef].instance; } }, methods: { getRecordCount() { const dataSource = this.dataGrid.getDataSource(); return dataSource.items().length; } } } </script>- ReactApp.js- import React, { useRef, useCallback } from 'react'; import 'devextreme/dist/css/dx.light.css'; import DataGrid from 'devextreme-react/data-grid'; export default function App() { const dataGrid = useRef(null); const getRecordCount = useCallback(() => { const dataSource = dataGrid.current.instance().getDataSource(); return dataSource.items().length; }, []); return ( <DataGrid ref={dataGrid}> {/* ... */} </DataGrid> ); }
See Also
undeleteRow(rowIndex)
Recovers a row deleted in batch editing mode.
The row's index. Refer to Column and Row Indexes for more information.
See Also
If you have technical questions, please create a support ticket in the DevExpress Support Center.