treelist控件可以同时显示树结构和其他数据列,即在一个列上建立父子关系展开或收缩,同时还可以显示其他列的内容。
在treelist中同时引入了 node和 columns概念, 第一列为树结构, 其余列为数据列, 任何列都可作为树结构列(即拖动到第一列)显示。
实现多级树---数据源绑定
在treelist里添加要显示列(第一列为树结构,其他列为数据列),并指定fieldname为数据库列名
指定keyfieldname属性为主键,parentfieldname属性为树状分组列。注意 parentfieldname指定的列如果为空值,树状可能会混乱(只有一个根结点,其他为此节点的子结点)
用treelist.datasource = datatable 绑定数据即可
树形控件是使用频率很高的一种控件。对于属性控件往往需要下面两个功能:
1.treelist带有checkbox,并且节点要有三种状态(所有的子节点都选中,所有的子节点都没选择,一部分子节点选中)。使用devxpress的treelist控件很容易实现这一功能。
设置treelist.optionsview.showcheckboxes = true //是否显示checkbox
设置treelist.optionsbehavior.allowindeterminatecheckstate = true; //设置节点是否有中间状态,即一部分子节点选中,一部分子节点没有选中
设置这两个属性之后就实现了treelist带有checkbox,并且节点有三种状态。
2.选中父节点或者子节点相互影响的功能,如选择父节点选择所有子节点。绑定treelist的两个事件afterchecknode和beforechecknode
devexpress的treelist要想在节点前面显示复选框,得修改属性optionsview->showcheckboxes=true
复选框的子节点与父节点统一的规则有:
1、选择某一节点时,该节点的子节点全部选择
2、取消某一节点时,该节点的子节点全部取消选择
3、某节点的子节点全部选择时,该节点选择
4、某节点的子节点未全部选择时,该节点不选择