JavaScript/jQuery TreeView Options
accessKey
The value of this option will be passed to the accesskey
attribute of the HTML element that underlies the widget.
createChildren
If you have a large data source hosted remotely, loading all of it may take considerable time. To quicken the process, you can load data for an individual node using the createChildren function. This function will be called at the beginning of the widget's lifetime and each time a user expands a node whose child nodes have not been loaded yet.
jQuery
$(function() { $("#treeViewContainer").dxTreeView({ createChildren: function (parentNode) { var d = $.Deferred(); $.get("http://url/to/the/service", { parentId: parentNode ? JSON.stringify(parentNode.key) : "0" }) .done(function (result) { d.resolve(result); }); return d.promise(); }, dataStructure: 'plain' }); });
Angular
<dx-tree-view [createChildren]="createChildren" dataStructure="plain"> </dx-tree-view>
import { ..., Inject } from '@angular/core'; import { Http, HttpModule, URLSearchParams } from '@angular/http'; import 'rxjs/add/operator/toPromise'; import { DxTreeViewModule } from 'devextreme-angular'; // ... export class AppComponent { constructor(@Inject(Http) http: Http) { } createChildren = (parentNode) => { let params: URLSearchParams = new URLSearchParams(); params.set("parentId", parentNode ? JSON.stringify(parentNode.key) : "0"); return http.get("http://url/to/the/service", { search: params }) .toPromise() .then(response => { return response.json() }); } } @NgModule({ imports: [ // ... DxTreeViewModule, HttpModule ], // ... })
See Also
dataSource
This option accepts one of the following.
Array of objects
A simple JavaScript array containing a collection of plain objects.URL
A URL to JSON data or to a service returning data in JSON format.DataSource or its configuration object
A DataSource is an object that provides a handy API for data processing. A DataSource is a stateful object, which means that it saves data processing settings and applies them each time data is loaded. All underlying data access logic of a DataSource is isolated in a Store. A Store provides an API for reading and modifying data. Unlike the DataSource, a Store is a stateless object.
.
, ,
, :
, [
, and ]
. Their presence may cause issues in the widget's operation.If the data source is specified using the dataSource option, use the items option only for reading. Updating data items using the items option may cause unexpected results.
To display widget items, a default template can be used. This template is based on the data source fields that are listed in the Default Item Template section of the widget's API. Alternatively, you can implement a custom item template. For details, refer to the Customize Node Appearance topic.
See Also
- createChildren - allows you to load nodes manually.
dataStructure
If the option is set to 'tree', the array should have a tree structure. This means that each item can contain the items field, which contains an array of nested items.
var treeViewData = [ { id: 1, items: [ { id: 11 }, { id: 12 }, { id: 13, items: [ { id: 131 }, { id: 132 }, { id: 133 }, ] }, ] }, { id: 2 } ];
If the dataStructure option value is 'plain', the array should have a plain structure. In this case, each array item should contain the parentId field, which specifies the key of the parent item.
var treeViewData = [ { id: 1, parentId: 0 }, { id: 11, parentId: 1 }, { id: 12, parentId: 1 }, { id: 13, parentId: 1 }, { id: 131, parentId: 13 }, { id: 132, parentId: 13 }, { id: 133, parentId: 13 }, { id: 2, parentId: 0 } ];
When using the widget as an ASP.NET MVC Control, specify this option using the TreeViewDataStructure
enum. This enum accepts the following values: Plain
and Tree
.
See Also
disabledExpr
Specifies the name of the data source item field whose value defines whether or not the corresponding widget item is disabled.
elementAttr
Specifies the attributes to be attached to the widget's root element.
You can configure this option in an ASP.NET MVC Control as follows:
@(Html.DevExtreme().WidgetName() .ElementAttr("class", "class-name") // ===== or ===== .ElementAttr(new { @id = "elementId", @class = "class-name" }) // ===== or ===== .ElementAttr(new Dictionary<string, object>() { { "id", "elementId" }, { "class", "class-name" } }) )
@(Html.DevExtreme().WidgetName() _ .ElementAttr("class", "class-name") ' ===== or ===== .ElementAttr(New With { .id = "elementId", .class = "class-name" }) ' ===== or ===== .ElementAttr(New Dictionary(Of String, Object) From { { "id", "elementId" }, { "class", "class-name" } }) )
expandedExpr
Specifies the name of the data source item field whose value defines whether or not the corresponding widget item is displayed expanded.
hasItemsExpr
Specifies the name of the data source item field whose value defines whether or not the corresponding node includes child nodes.
height
This option accepts a value of one of the following types:
Number
The height in pixels.String
A CSS-accepted measurement of height. For example,"55px"
,"80%"
,"auto"
,"inherit"
.Function
A function returning either of the above. For example:JavaScriptheight: function() { return window.innerHeight / 1.5; }
items
Array<dxTreeViewItemTemplate>
You can use the dataSource option instead. Unlike the items option, the dataSource option can take on the DataSource configuration object as well as a simple array.
To display widget items, a default template can be used. This template is based on the data source fields that are listed in the Default Item Template section of the widget's API.
itemsExpr
Specifies which data field contains nested items. Applies only if the dataStructure option is "tree".
onContentReady
A handler for the contentReady event. Executed when the widget's content is ready. This handler may be executed multiple times during the widget's lifetime depending on the number of times its content changes.
Name | Type | Description |
---|---|---|
component |
The widget's instance. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
The model data. Available only when using Knockout. |
onDisposing
A handler for the disposing event. Executed when the widget is removed from the DOM using the remove(), empty(), or html() jQuery methods only.
Name | Type | Description |
---|---|---|
component |
The widget's instance. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
The model data. Available only if you use Knockout. |
onInitialized
Name | Type | Description |
---|---|---|
component |
The widget's instance. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
You cannot access widget elements in this handler because it is executed before they are ready. Use the onContentReady handler instead.
onItemClick
A handler for the itemClick event.
Name | Type | Description |
---|---|---|
node |
The item's node. |
|
model |
The model data. Available only if Knockout is used. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
component |
The widget's instance. |
onItemCollapsed
A handler for the itemCollapsed event.
Name | Type | Description |
---|---|---|
component |
The widget's instance. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
The model data. Available only if Knockout is used. |
|
itemData |
The collapsed item's data. |
|
itemElement |
The item's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
itemIndex |
The item's index. |
|
jQueryEvent |
Use 'event' instead. The jQuery event that caused the handler execution. Deprecated in favor of the event field. |
|
event | Event (jQuery or EventObject) |
The event that caused the handler execution. It is a dxEvent or a jQuery.Event when you use jQuery. |
node |
The item's node. |
Assign a function to perform a custom action when a tree view item is collapsed.
See Also
onItemContextMenu
A handler for the itemContextMenu event.
Name | Type | Description |
---|---|---|
node |
The item's node. |
|
model |
The model data. Available only if Knockout is used. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
component |
The widget's instance. |
onItemExpanded
A handler for the itemExpanded event.
Name | Type | Description |
---|---|---|
component |
The widget's instance. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
The model data. Available only if Knockout is used. |
|
itemData |
The expanded item's data. |
|
itemElement |
The item's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
itemIndex |
The item's index. |
|
jQueryEvent |
Use 'event' instead. The jQuery event that caused the handler execution. Deprecated in favor of the event field. |
|
event | Event (jQuery or EventObject) |
The event that caused the handler execution. It is a dxEvent or a jQuery.Event when you use jQuery. |
node |
The item's node. |
Assign a function to perform a custom action when a tree view item is expanded.
See Also
onItemHold
A handler for the itemHold event.
Name | Type | Description |
---|---|---|
node |
The item's node. |
|
model |
The model data. Available only if Knockout is used. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
component |
The widget's instance. |
onItemRendered
A handler for the itemRendered event.
Name | Type | Description |
---|---|---|
node |
The item's node. |
|
model |
The model data. Available only if Knockout is used. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
component |
The widget's instance. |
onItemSelected
Use the onItemSelectionChanged property instead.
A handler for the itemSelected event.
Name | Type | Description |
---|---|---|
component |
The widget's instance. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
The model data. Available only if Knockout is used. |
|
itemElement |
The selected item's container. |
|
node |
The selected item's node. |
onItemSelectionChanged
A handler for the itemSelectionChanged event.
Name | Type | Description |
---|---|---|
component |
The widget's instance. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
The model data. Available only if Knockout is used. |
|
node |
The selected item's node. |
|
itemElement |
The selected item's container. |
This option makes sense in one of the following cases.
- The selectByClick option is set to true.
- The showCheckBoxesMode option is not set to 'none'.
- You use one of the methods: selectAll, unselectAll, selectItem, unselectItem.
See Also
onOptionChanged
Name | Type | Description |
---|---|---|
name |
The option's short name. |
|
model |
The model data. Available only if you use Knockout. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
component |
The widget's instance. |
|
fullName |
The option's full name. |
|
value | any |
The option's new value. |
onSelectAllValueChanged
A function that is executed after the "Select All" check box's state changes. Applies only if showCheckBoxesMode is "selectAll" and selectionMode is "multiple".
Name | Type | Description |
---|---|---|
component |
The widget's instance. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
The model data. Available only if Knockout is used. |
|
value |
The "Select All" check box's new state. |
onSelectionChanged
A handler for the selectionChanged event. Executed after selecting an item or clearing its selection.
Name | Type | Description |
---|---|---|
component |
The widget's instance. |
|
element |
The widget's container. It is an HTML Element or a jQuery Element when you use jQuery. |
|
model |
The model data. Available only if Knockout is used. |
This handler is executed under one of the following conditions:
- The selectByClick option is true;
- The showCheckBoxesMode option is not 'none';
- The selectAll, unselectAll, selectItem or unselectItem method is called.
parentIdExpr
Specifies the name of the data source item field for holding the parent key of the corresponding node.
rtlEnabled
When this option is set to true, the widget text flows from right to left, and the layout of elements is reversed. To switch the entire application/site to the right-to-left representation, assign true to the rtlEnabled field of the object passed to the DevExpress.config(config) method.
DevExpress.config({ rtlEnabled: true });
See Also
- Right-to-Left Support Demo: DataGrid | Navigation Widgets | Editors
scrollDirection
When using the widget as an ASP.NET MVC Control, specify this option using the ScrollDirection
enum. This enum accepts the following values: Vertical
, Horizontal
and Both
.
searchEditorOptions
See the TextBox Configuration for options you can specify in this object.
searchMode
Specifies whether the widget finds entries that contain your search string or entries that only start with it.
When using the widget as an ASP.NET MVC Control, specify this option using the CollectionSearchMode
enum. This enum accepts the following values: Contains
and StartsWith
.
searchValue
See Also
selectAllEnabled
Use the showCheckBoxesMode property instead.
Use this option only if the showCheckBoxes option value is true.
selectedExpr
Specifies the name of the data source item field whose value defines whether or not the corresponding widget items is selected.
selectionMode
When using the widget as an ASP.NET MVC Control, specify this option using the NavSelectionMode
enum. This enum accepts the following values: Single
and Multiple
.
showCheckBoxesMode
The option accepts the following values.
'none'
The widget does not display check boxes.'normal'
The widget displays a check box for each item.'selectAll'
The widget displays a check box for each item and the 'select all' check box at the top of the widget.
When using the widget as an ASP.NET MVC Control, specify this option using the TreeViewCheckBoxMode
enum. This enum accepts the following values: None
, Normal
and SelectAll
.
See Also
tabIndex
The value of this option will be passed to the tabindex
attribute of the HTML element that underlies the widget.
virtualModeEnabled
If the option is set to true, the widget initially loads only root items. Child items are loaded when their parent is being expanded.
Use this option to improve the widget performance when working with a huge data source.
See Also
- Enhance Performance on Large Datasets
- createChildren - allows you to load nodes manually.
width
This option accepts a value of one of the following types:
Number
The width in pixels.String
A CSS-accepted measurement of width. For example,"55px"
,"80%"
,"auto"
,"inherit"
.Function
A function returning either of the above. For example:JavaScriptwidth: function() { return window.innerWidth / 1.5; }
If you have technical questions, please create a support ticket in the DevExpress Support Center.