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));
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值