效果图
废话不多说,首先新建一个TreeList,命名为tlistBOM
然后新建一个datatable 明明为dt
dt.Columns.Add("StationNo", Type.GetType("System.String"));
dt.Columns.Add("SegmentName", Type.GetType("System.String"));
dt.Columns.Add("psgmt", Type.GetType("System.String"));
dt.Columns.Add("qty", Type.GetType("System.Int32"));
dt.Rows.Add("1", "工位1", "",2);
dt.Rows.Add("2", "工位2", "", 2);
dt.Rows.Add("3", "工位3", "", 2);
dt.Rows.Add("1.1", "工位1.1", "1", 2);
dt.Rows.Add("1.2", "工位1.2", "1", 2);
dt.Rows.Add("1.3", "工位1.3", "1", 2);
dt.Rows.Add("2.1", "工位2.1", "2", 2);
dt.Rows.Add("2.2", "工位2.2", "2", 2);
dt.Rows.Add("2.3", "工位2.3", "2", 2);
dt.Rows.Add("2.1.1", "工位2.1.1", "2.1", 2);
然后把dt作为数据源绑定到tlistBOM
this.tlistBOM.DataSource = dt;
this.tlistBOM.KeyFieldName = "StationNo";
this.tlistBOM.ParentFieldName = "psgmt";
this.tlistBOM.Tag = "SegmentName";
this.tlistBOM.EndUpdate();
this.tlistBOM.ExpandAll();
绑定之后,还不行,还需要新建column并绑定数据源,用来把表格中的数据显示出来
从最终的显示效果来看
//这一行最为子节点的依据,就算绑定了数据也不显示
this.tlistBOM.KeyFieldName = "StationNo";
//这一行最为父节点的依据,就算绑定了数据也不会显示
this.tlistBOM.ParentFieldName = "psgmt";
怎么获取节点内容?
原文章链接:https://bbs.csdn.net/topics/391956895
var x = treeList1.FocusedNode.ParentNode.GetValue("Name").ToString();
取当前选择节点的父节点,获取某个字段的值
按照此代码思路往下走,我们进行一下测试
先选中所有列,设置都不可编辑,
然后编写treelist的单击事件代码如下
private void tlistBOM_Click(object sender, EventArgs e)
{
TreeListNode parentNode = tlistBOM.FocusedNode.ParentNode;
if (parentNode != null)
{
//string toString = parentNode.GetValue("StationNo").ToString();
lblInfo.Text = "父节点为"+parentNode.GetValue("StationNo").ToString();
}
else
{
lblInfo.Text = "不存在父节点";
}
}
测试效果如下
说到这里,接下来的事情就好做了,
结:
1、首先明确了数据源结构问题
2、明确了数据源绑定的问题
3、明确了数据源显示的问题
4、明确了节点值的获取问题
5、进行了节点值获取之后简单代码的演示
最后展现一张树形结构的数据应用场景图