WPF数据绑定(二)

前面讲了最近本的两种数据绑定,这次讲讲资源绑定和Context绑定

1、资源绑定

同样不需要写代码,仅仅需要配置XAML就可以了。

1             <TabItem Header="ResourceBinding">
2                 <StackPanel>
3                     <StackPanel.Resources>
4                         <sys:String x:Key="string1">this is a static string resource</sys:String>
5                     </StackPanel.Resources>
6                     <TextBlock HorizontalAlignment="Center" VerticalAlignment="Center" Text="{Binding Source={StaticResource string1}}" />
7                     <TextBlock Text="{Binding Path=Name, RelativeSource={RelativeSource AncestorLevel=2, Mode=FindAncestor, AncestorType={x:Type Grid}}}" />
8                 </StackPanel>
9             </TabItem>

其中第六行中Textblock的Text属性就是针对静态属性的绑定。绑定的时一个字符串资源,资源的定义在第四行。

第七行的TextBlock是什么绑定呢?这个叫相对资源绑定,前面的静态资源是绝对资源,比如我们在例子中用到的字符串就是stackpanel的一个资源,他的“位置”,从属关系是绝对的。

而相对资源是以当前空间为出发点的相对位置,比如说在例子中的绑定的资源就是相对于该TextBlock的外围的Grid的控件的的Name属性。

重点是下面这句话:

RelativeSource={RelativeSource AncestorLevel=2, Mode=FindAncestor, AncestorType={x:Type Grid}}

AncestorLevel这个是相对的控件的偏移量,从1开始,每层向外加1,Mode是找寻的模式,这里的FindAncestor时说找祖先(Ancestor意为祖先),就是说找父控件,即外层的空件。AncestorType就是要找哪类控件。

2、Context绑定

同样不需要写代码

 1             <TabItem Header="context binding">
 2                 <StackPanel>
 3                     <StackPanel.DataContext>
 4                         <local:Student Id="15" Name="Jean" Age="18"/>                        
 5                     </StackPanel.DataContext>
 6                     <TextBlock Text="{Binding Id}"/>
 7                     <TextBlock Text="{Binding Name}"/>
 8                     <TextBlock Text="{Binding Age}"/>
 9                 </StackPanel>
10             </TabItem>

我们原本定义了一个student类,现在给Stackpanel类设置一个DataContext,一个学生类。

同时让TextBlock类的控件来绑定的显示该学生类的信息。

显示效果如下:

 当然我们也可以使用代码来实现,将StackPanel类设置为一个学生类。效果是一样的

代码下载:

https://github.com/Dothegod/WPF_Training_Sample

原文地址:https://www.cnblogs.com/HighFun/p/2870573.html