Vue TreeList - Sorting

User Interaction

With the TreeList UI component, a user can sort by single and multiple columns. Use the sorting.mode property to specify the current sorting mode.

App.vue
  • <template>
  • <DxTreeList>
  • <DxSorting mode="single"/> <!-- or "multiple" | "none" -->
  • </DxTreeList>
  • </template>
  •  
  • <script>
  • import 'devextreme/dist/css/dx.light.css';
  •  
  • import { DxTreeList, DxSorting } from 'devextreme-vue/tree-list';
  •  
  • export default {
  • components: {
  • DxTreeList,
  • DxSorting
  • }
  • }
  • </script>

In single mode, the user can click a column header to sort by the column. Subsequent clicks on the same header reverse the sort order. When the user sorts by a column, the sorting settings of other columns are canceled.

In multiple mode, the user clicks a column header while pressing the Shift key to sort by the column. Sorting settings of other columns remain intact.

In both modes, the user can use the column header's context menu to apply sorting. Note that no matter how user applies sorting, rows are sorted within their hierarchical level.

DevExtreme HTML5 JavaScript jQuery Angular Knockout UI component TreeList Sorting

To cancel a column's sorting settings, the user clicks the column's header while pressing Ctrl or uses the context menu:

DevExtreme HTML5 JavaScript jQuery Angular Knockout UI component TreeList Sorting

To disable sorting in the whole UI component, set the sorting.mode property to "none"; to disable sorting only in a specific column, use its allowSorting property.

App.vue
  • <template>
  • <DxTreeList>
  • <DxColumn :allow-sorting="false"/>
  • </DxTreeList>
  • </template>
  •  
  • <script>
  • import 'devextreme/dist/css/dx.light.css';
  •  
  • import { DxTreeList, DxColumn } from 'devextreme-vue/tree-list';
  •  
  • export default {
  • components: {
  • DxTreeList,
  • DxColumn
  • }
  • }
  • </script>
See Also

API

Initial and Runtime Sorting

Rows are sorted according to the data source by default. Set the sortOrder property to sort rows in the required order. Specify the sortIndex property as well to sort by multiple columns. Otherwise, each sorted column gets a sort index according to its position in the columns array. For example, the following code sorts rows first by the "Surname", then by the "Name" column:

App.vue
  • <template>
  • <DxTreeList>
  • <DxColumn
  • data-field="City"
  • :sort-index="1"
  • sort-order="asc"
  • />
  • <DxColumn
  • data-field="Country"
  • :sort-index="0"
  • sort-order="asc"
  • />
  • </DxTreeList>
  • </template>
  •  
  • <script>
  • import 'devextreme/dist/css/dx.light.css';
  •  
  • import { DxTreeList, DxColumn } from 'devextreme-vue/tree-list';
  •  
  • export default {
  • components: {
  • DxTreeList,
  • DxColumn
  • }
  • }
  • </script>

Change the sortOrder and sortIndex properties using the columnOption method to sort at runtime.

App.vue
  • <template>
  • <DxTreeList ...>
  • <DxColumn
  • data-field="Country"
  • v-model:sort-order="countrySortOrder"
  • />
  • </DxTreeList>
  • </template>
  •  
  • <script>
  • import 'devextreme/dist/css/dx.light.css';
  •  
  • import { DxTreeList, DxColumn } from 'devextreme-vue/tree-list';
  •  
  • export default {
  • components: {
  • DxTreeList,
  • DxColumn
  • },
  • data() {
  • return {
  • countrySortOrder: "asc"
  • }
  • },
  • methods: {
  • sortByCountries(order) {
  • this.countrySortOrder = order;
  • }
  • }
  • }
  • </script>

View Demo

Custom Sorting

Implement a custom sorting routine using the calculateSortValue property if standard sorting does not meet your requirements. It accepts the name of the data source field that provides values to be used in sorting...

App.vue
  • <template>
  • <DxTreeList>
  • <!-- data-field provides values for the column -->
  • <!-- calculate-sort-value provides values to be used in sorting -->
  • <DxColumn
  • data-field="Position"
  • calculate-sort-value="isOnVacation"
  • />
  • </DxTreeList>
  • </template>
  •  
  • <script>
  • import 'devextreme/dist/css/dx.light.css';
  •  
  • import { DxTreeList, DxColumn } from 'devextreme-vue/tree-list';
  •  
  • export default {
  • components: {
  • DxTreeList,
  • DxColumn
  • }
  • }
  • </script>

...or a function that returns such a value.

App.vue
  • <template>
  • <DxTreeList ...>
  • <DxColumn
  • data-field="Position"
  • sort-order="asc"
  • :calculate-sort-value="calculateSortValue"
  • />
  • </DxTreeList>
  • </template>
  •  
  • <script>
  • import 'devextreme/dist/css/dx.light.css';
  •  
  • import { DxTreeList, DxColumn } from 'devextreme-vue/tree-list';
  •  
  • export default {
  • components: {
  • DxTreeList,
  • DxColumn
  • },
  • data() {
  • return {
  • calculateSortValue(rowData) {
  • if (rowData.Position == "CEO")
  • return this.sortOrder == 'asc' ? "aaa" : "zzz"; // CEOs are always displayed at the top
  • else
  • return rowData.Position; // Others are sorted as usual
  • }
  • };
  • }
  • }
  • </script>

Clear Sorting Settings

You can clear sorting settings for all columns by calling the clearSorting() method, or for a specific column - by setting its sortIndex property to undefined using the columnOption method.

App.vue
  • <template>
  • <DxTreeList :ref="treeListRefKey">
  • <DxColumn
  • data-field="Name"
  • v-model:sort-index="nameSortIndex"
  • />
  • </DxTreeList>
  • </template>
  •  
  • <script>
  • import 'devextreme/dist/css/dx.light.css';
  •  
  • import { DxTreeList, DxColumn } from 'devextreme-vue/tree-list';
  •  
  • const treeListRefKey = "my-tree-list";
  •  
  • export default {
  • components: {
  • DxTreeList
  • },
  • data() {
  • return {
  • treeListRefKey,
  • nameSortIndex: 0
  • };
  • },
  • methods: {
  • clearNameColumnSorting() {
  • this.nameSortIndex = undefined;
  • },
  • clearAllSorting() {
  • this.treeList.clearSorting();
  • }
  • },
  • computed: {
  • treeList() {
  • return this.$refs[treeListRefKey].instance;
  • }
  • }
  • }
  • </script>
See Also