WPF中的数据绑定(一)

WPF中提供的代码帮顶技术有很多种,可以根据不同的情况使用不同的方法,十分灵活,下面根据不同的情况进行设置。

WPF数据绑定(二)

1、通过代码绑定

 WPF中的数据绑定(一)

1             <TabItem Header="CodeBinding">

2                 <Grid>

3                     <Button Content="Button" HorizontalAlignment="Left" Margin="49,116,0,0" VerticalAlignment="Top" Width="75" Click="Button_Click_1"/>

4                     <TextBox Name="tbCode"  HorizontalAlignment="Left" Height="22" Margin="49,55,0,0" TextWrapping="Wrap" VerticalAlignment="Top" Width="120"/>

5                     <Button Content="Button" HorizontalAlignment="Left" Margin="259,116,0,0" VerticalAlignment="Top" Width="75" Click="Button_Click_2"/>

6                     <TextBox Name="tbCode1"  HorizontalAlignment="Left" Height="22" Margin="259,55,0,0" TextWrapping="Wrap" VerticalAlignment="Top" Width="120"/>

7                 </Grid>

8             </TabItem>

   你可以这样在代码设置

先看看studen类的实现

 1     class Student : INotifyPropertyChanged

 2     {

 3         public string Age { get; set; }

 4         public string Id { get; set; }

 5         private string m_Name;

 6         public string Name

 7         {

 8             get

 9             {

10                 return m_Name;

11             }

12             set

13             {

14                 m_Name = value;

15                 if (PropertyChanged != null)

16                 {

17                     this.PropertyChanged.Invoke(this, new PropertyChangedEventArgs("Name"));

18                 }

19             }

20         }

21 

22         public event PropertyChangedEventHandler PropertyChanged;

23     }

这个各类继承自INotifyPropertyChanged,这个接口的事要目的就是为了在Name属性被改写的时候会通知到你绑定的目标对象去,使目标也已一起变化。属性如果要绑定,需要继承INotifyPropertyChanged接口。

1     // 摘要:

2     //     向客户端发出某一属性值已更改的通知。

3     public interface INotifyPropertyChanged

4     {

5         // 摘要:

6         //     在更改属性值时发生。

7         event PropertyChangedEventHandler PropertyChanged;

8     }

其实我一开始很纠结,因为PropertyChanged没有让我亲自实现,总是觉得很别扭,这厮是怎么被工作的,其实当你完成数据绑定的时候,会自动给这个时间加一个实现的。我们不需要去管它。

点击按钮的话我会创建一个student类,给Name属性赋值,然后将这个对象绑定到tbcode的Text属性上。

1         private void Button_Click_1(object sender, RoutedEventArgs e)

2         {

3             Student st = new Student();

4             st.Name = "Jim";

5             Binding bd = new Binding();

6             bd.Source = st;

7             bd.Path = new PropertyPath("Name");

8             BindingOperations.SetBinding(tbCode, TextBox.TextProperty, bd);

9         }

里面有两个比较重要的属性,一个是source一个是path,source是Binding的的源,就是说你的数据源在哪里,另外一个是path就是路径,就是要绑定的具体的数据源是哪个,设置好这两个以后,就可以把这个Binding绑定到你的目标对象上——tbCode,使用BindingOperations.SetBinding,第一个参数是要绑定的对象,第二个参数是你要在这个对象的那个属性上,第三个参数就是之前设置的Binding。

当然这种写法也可以简化

1         private void Button_Click_2(object sender, RoutedEventArgs e)

2         {

3             Student st = new Student();

4             st.Name = "Mike";

5             tbCode1.SetBinding(TextBox.TextProperty, new Binding("Name") { Source = st });

6         }
tbCode1.SetBinding这个的实现就是把上面的BindingOperations.SetBinding进行了一个封装。
不过有一点我不明白,我是先给st赋值的,然后再进行绑定,为什么这个时候也会同时textblock空间进行更新呢?希望高手指点。

2、UIElementBInding绑定
这个绑定很简单,也很常用。
如果我有一个silder,一个textbox来显示他的value,应该怎么做?当然你可以实现ValueChanged方法。但是用绑定会更加的灵活。

WPF中的数据绑定(一)

1             <TabItem Header="UIElementBInding">

2                 <Grid>

3                     <Slider x:Name="slider" HorizontalAlignment="Left" Margin="50,195,0,0" VerticalAlignment="Top" Width="393"/>

4                     <TextBox HorizontalAlignment="Left" Height="23" Margin="113,77,0,0" TextWrapping="Wrap" VerticalAlignment="Top" Width="120" Text="{Binding Value, ElementName=slider}"/>

5 

6                 </Grid>

7             </TabItem>

你不需要写一行C#代码就能够完成。Text="{Binding Value, ElementName=slider}"意思是要绑定到哪个控件(slider)的哪个属性(Value)上。

C#的绑定有很多,这里先介绍两种,剩下的后面会一一介绍。

代码地址:

https://github.com/Dothegod/WPF_Training_Sample

你可能感兴趣的:(数据绑定)