有时候我们不确定作为数据源的对象叫什么名字,但知道作为绑定源与UI布局有相对的关系,如下是一段XAML代码,说明多层布局控件中放置一个文本控件,来显示父级控件的名称。
1、XAML
<Grid x:Name="g1" Background="Red" Margin="10"> <DockPanel x:Name="d1" Background="Orange" Margin="10"> <Grid x:Name="g2" Background="Yellow" Margin="10"> <DockPanel x:Name="d2" Background="LawnGreen" Margin="10"> <TextBox x:Name="textBox1" FontSize="24" Margin="10"/> </DockPanel> </Grid> </DockPanel> </Grid>2、后台代码 RelativeSource rs = new RelativeSource(RelativeSourceMode.FindAncestor);//设定为离自己控件最近的第二层父控件 rs.AncestorLevel = 2;//设定父控件为Gird类型 rs.AncestorType = typeof(Grid);//绑定源为Grid的名称 Binding binding = new Binding("Name") { RelativeSource=rs};//将绑定的源放在文本显示内容中 this.textBox1.SetBinding(TextBox.TextProperty, binding);
3、以上后台代码等同于XAML中的 <TextBox x:Name="textBox1" FontSize="24" Margin="10" Text="{Binding RelativeSource={RelativeSource FindAncestor,AncestorType={x:Type Grid},AncestorLevel=2},Path=Name}"/>
本文详细介绍了如何在XAML中通过C#后台代码实现多层布局控件间的相对绑定,以显示父级控件的名称。包括XAML代码示例、后台代码解析及等效XAML表达方式。
1633

被折叠的 条评论
为什么被折叠?



