WPF数据绑定详解

元素绑定

数据绑定最简单的形式是,源对象是WPF元素而且源属性是依赖属性。依赖项属性具有内置的更改通知支持,当在源对象中改变依赖项属性的值时,会立即更新目标对相中的绑定属性。

<!--Xaml程序 -->
<Grid>
    <StackPanel> <Button x:Name="btn" Margin="20" Click="btn_Click" Width="40" Height="35"/> <TextBox Text="{BindingElementName=txt2,Path=Text,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}"/> <!-- TextBox绑定属性名为txt2,绑定其Text,双向绑定,属性改变时更新 --> <TextBlock x:Name="txt2" /> </StackPanel> </Grid> 
//后台程序

public partial class MainWindow : Window { public MainWindow() { InitializeComponent(); } private void btn_Click(object sender, RoutedEventArgs e) { txt2.Text += "k"; } } 



BindingMode枚举值
名称 说明
OneWay 当源属性变化时更新目标属性
TwoWay 当源属性变化时更新目标属性,当目标属性变化时更新源属性
OneTime 最初根据源属性设置目标属性,其后的改变会忽略。
OneWayToSource 与OneWay类型相似,但方向相反。
Default 此类绑定依赖于目标属性



UpdateSourceTrigger
名称 说明
Default 默认值,与依赖属性有关
Explicit 必须在显示地调用BindingExpression.UpdateSource的情况下才更新源。
LostFocus 控件失去焦点的时候更新源值
PropertyChanged 绑定的目标值改变时更新。
数据绑定
<!-- Xaml程序 -->
<Grid>
    <StackPanel> <DataGrid ItemsSource="{Binding PerList}" IsReadOnly="True"></DataGrid> <ComboBox x:Name="com" ItemsSource="{Binding PerList}" DisplayMemberPath="Name" Margin="10" Width="80" Height="30"/> <!--绑定PerList,展示其Name属性 --> </StackPanel> </Grid> 
//后台程序
public partial class MainWindow : Window { public List<string> LT { get; set; } List<Person> Perss { get; set; } public MainWindow() { PersonList perlist = new PersonList(); //创建一个PersonList对象 Perss = new List<Person>() { new Person("Getsu1","男"), new Person("Getsu2", "男"), new Person("Getsu3", "男")}; perlist.PerList = Perss; //给PerList属性赋值 this.DataContext = perlist; //将perlist加入上下文,设置之后绑定才会有效 } } public class PersonList { public List<Person> PerList { get; set; } public PersonList() { PerList = new List<Person>(); } public class Person { private string _name; private string _sex; public string Name { get { return _name; } set{ _name = value; } } public string Sex { get { return _sex; } set{ _sex = value; } } public Person(string name, string sex) { Name = name; Sex = sex; } } } 
INotifyPropertyChanged

属性更改通知接口。向客户端发出某一属性已更改的通知。
event PropertyChangedEventHandler PropertyChanged;
PropertyChanged 在属性改变时发生。

<!-- X -->
 <StackPanel>
    <TextBox Text="{Binding Name,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}"></TextBox> <TextBox Text="{Binding Sex,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}"></TextBox> <TextBlock Text="{Binding Name,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}"/> <!-- 不会随着TextBox内容的改变而改变--> <TextBlock Text="{Binding Sex,Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}"/> <!-- 会随着TextBox内容的改变而改变--> </StackPanel> 
//后台程序
public partial class MainWindow : Window { public MainWindow() { Person per = new Person("kakarot", "Male"); this.DataContext = per; InitializeComponent(); } } public class Person : INotifyPropertyChanged { public event PropertyChangedEventHandler PropertyChanged; private string _name; private string _sex; public string Name { get { return _name; } set { _name = value; //NotifyPropertyChanged("Name"); } } public string Sex { get { return _sex; } set { _sex = value; NotifyPropertyChanged("Sex"); } } private void NotifyPropertyChanged(String info) { if (PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(info)); } } public Person(string name, string sex) { Name = name; Sex = sex; } } 
特性
public string Sex
{
    get { return _sex; }
    set
    {
        _sex = value;
        NotifyPropertyChanged();
        //使用特性之后可以自动获取属性名 } } //特性的表示 private void NotifyPropertyChanged([CallerMemberName]String info="默认值") { if (PropertyChanged != null) { PropertyChanged(this, new PropertyChangedEventArgs(info)); } }


作者:GetsuKami
链接:https://www.jianshu.com/p/fc644333a9e5
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

猜你喜欢

转载自www.cnblogs.com/Jeely/p/11076706.html