原址:https://www.cnblogs.com/Im-Victor/p/11444189.html https://blog.csdn.net/kenjianqi1647/article/details/90320569
<!--绑定到DataContext--> <Button Content="{Binding DataTime}"/>
<!--绑定到DataContext,并设置绑定模式--> <Button x:Name="btn" Content="{Binding DataTime,Mode=OneTime}"/>
<!--绑定到DataContext,并设置更新模式--> <Button Content="{Binding DataTime,UpdateSourceTrigger=PropertyChanged}"/>
<!--绑定到DataContext,并设置转换模式--> <Button Content="{Binding DataTime,Converter={StaticResource ConvertResource},ConverterParameter=btn1}"/>
<!--绑定到Element中指定属性--> <Button Content="{Binding ElementName=btn,Path=Content}"/>
<!--绑定到相对位置中的自身模式--> <Button Content="{Binding RelativeSource={RelativeSource Mode=Self},Path=Tag}" Tag="MyTag"/>
<!--绑定到相对位置中的父级别查找模式--> <Button Content="{Binding RelativeSource={RelativeSource Mode=FindAncestor,AncestorType=Window},Path=Content}"/>
<!--绑定到相对位置中的父级别查找模式 绑定到指定类型--> <Button Content="{Binding RelativeSource={RelativeSource Mode=FindAncestor,AncestorType=Window},Path=Content}"/>
<!--绑定到相对位置中的父级别查找模式 绑定到指定层级--> <Button Content="{Binding RelativeSource={RelativeSource Mode=FindAncestor,AncestorLevel=2},Path=Content}"/>
<!--绑定到相对位置中的父级别查找模式 绑定到模板内容--> <Button Content="{Binding RelativeSource={RelativeSource Mode=TemplatedParent},Path=Content}"/>
在使用Binding类的时候有4中绑定模式可以选择
BindingMode
TwoWay:
导致对源属性或目标属性的更改可自动更新对方。此绑定类型适用于可编辑窗体或其他完全交互式 UI 方案。
OneWay:
当绑定源(源)更改时,更新绑定目标(目标)属性。如果要绑定的控件为隐式只读控件,则适用此绑定类型。例如,可以绑定到如股市代号之类的源。或者,可能目标属性没有用于进行更改(例如表的数据绑定背景色)的控件接口。如果不需要监视目标属性的更改,则使用 OneWay 绑定模式可避免 TwoWay 绑定模式的系统开销。
OneTime:
当应用程序启动或数据上下文更改时,更新绑定目标。此绑定类型适用于以下情况:使用当前状态的快照适合使用的或数据状态实际为静态的数据。如果要从源属性初始化具有某个值的目标属性,并且事先不知道数据上下文,则也可以使用此绑定类型。实质上,这是 OneWay 绑定的较简单的形式,它在不更改源值的情况下可提供更好的性能。
OneWayToSource :
当目标属性更改时更新源属性。
Default:
使用绑定目标的默认 Mode 值。每个依赖项属性的默认值都不同。一般情况下,用户可编辑控件属性(例如文本框和复选框的属性)默认为双向绑定,而多数其他属性默认为单向绑定。确定依赖项属性绑定在默认情况下是单向还是双向的编程方法是:使用 GetMetadata 来获取属性的属性元数据,然后检查 BindsTwoWayByDefault 属性的布尔值。
使用 Mode 属性指定绑定的方向。以下枚举列表列出了可供绑定更新的选项:
-
无论是目标属性还是源属性,只要发生了更改,TwoWay 就会更新目标属性或源属性。
-
OneWay 仅当源属性发生更改时更新目标属性。
-
OneTime 仅当应用程序启动时或 DataContext 进行更改时更新目标属性。
-
OneWayToSource 在目标属性更改时更新源属性。
-
Default:使用目标属性的默认 Mode 值。
仍然使用上个文章中的文本框,标签控件,以及滚动条来说明绑定模式不同
1。使用twoway方式绑定以后,如果手动更改textbox的值,此时如果通过按钮事件来查看滚动条的value值,就会发现和textbox是一致
2。oneway方式,就是滚动条改变的时候会改变文本框的显示值,但是文本框更改的时候不会更改滚动条的值
3。onetime方法,会发现文本框的值会是滚动条的初始值。而且不会变化
4。onewaytosource。就是文本框更改的时候会改变源的属性。这个时候其实数据源和数据目标已经颠倒过来了
5。default方式,这个方式完全就是根据控件的属性来设置的。有的属性适合twoway方式,比如交互的UI控件,有点只能oneway方式
例:
前:
<Window x:Class="WpfApp2_bindingTest_2019121101.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:WpfApp2_bindingTest_2019121101" mc:Ignorable="d" Title="MainWindow" Height="450" Width="800"> <Grid>
<StackPanel> <!--slider front binding--> <TextBox x:Name="textBox1" Text="{Binding Path=Value,ElementName=slider1}"/> <Slider x:Name="slider1" Maximum="100" Minimum="0"/>
<TextBlock Text="Student ID:" FontWeight="Bold" Margin="5" /> <TextBox x:Name="textBoxId" Margin="5"/> <TextBlock Text="Student Age:" FontWeight="Bold" Margin="5" /> <TextBox x:Name="textBoxAge" Margin="5"/> <TextBlock Text="Student List:" FontWeight="Bold" Margin="5"/> <ListBox x:Name="listBoxStudents" Height="180" Margin="5"/>
<TextBox x:Name="textBoxName" BorderBrush="Black" Margin="5" /> <Button Content="Add Age" Margin="5" Click="Button_Click"/>
<!--<ListBox.ItemTemplate> </ListBox.ItemTemplate>-->
</StackPanel>
</Grid> </Window>
后:
using System; using System.Collections.Generic; using System.ComponentModel; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows; using System.Windows.Controls; using System.Windows.Data; using System.Windows.Documents; using System.Windows.Input; using System.Windows.Media; using System.Windows.Media.Imaging; using System.Windows.Navigation; using System.Windows.Shapes;
namespace WpfApp2_bindingTest_2019121101 { /// <summary> /// MainWindow.xaml 的交互逻辑 /// </summary> public partial class MainWindow : Window {
Students stu; public MainWindow() { InitializeComponent();
List<Student> stuList = new List<Student>() { new Student() { Id = 0, Name = "Tim", Age = 29 }, new Student() { Id = 1, Name = "Tom", Age = 28 }, new Student() { Id = 2, Name = "Kyle", Age = 27 }, new Student() { Id = 3, Name = "Tony", Age = 24 }, new Student() { Id = 4, Name = "Vina", Age = 23 }, new Student() { Id = 5, Name = "Mike", Age = 22 }, }; //为ListBox设置Binding this.listBoxStudents.ItemsSource = stuList;//数据源 this.listBoxStudents.DisplayMemberPath = "Name";//路径 //为TextBox设置Binding Binding binding = new Binding("SelectedItem.Id") { Source = this.listBoxStudents }; this.textBoxId.SetBinding(TextBox.TextProperty, binding); Binding bindingAge = new Binding("SelectedItem.Age") { Source = this.listBoxStudents }; this.textBoxAge.SetBinding(TextBox.TextProperty, bindingAge);
//准备数据源 stu = new Students(); //准备Binding Binding bindings = new Binding();//创建Binding实例 bindings.Source = stu;//指定数据源 bindings.Path = new PropertyPath("Name");//指定访问路径
//使用Binding 连接数据源与Bingding目标 BindingOperations.SetBinding(this.textBoxName, TextBox.TextProperty, bindings);//使用binding实例将数据源与目标关联起来 //参数为 目标;目标的某个属性
}
private void Button_Click(object sender, RoutedEventArgs e) { stu.Name += "Name11"; }
}
//创建一个名为Student的类,它具有Id、Name、Age三个属性 public class Student { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } }
class Students : INotifyPropertyChanged { public event PropertyChangedEventHandler PropertyChanged; private string name;
public string Name { get { return name; } set { name = value; if (this.PropertyChanged != null) { this.PropertyChanged.Invoke(this, new PropertyChangedEventArgs("Name"));//当Name的属性值发生改变时,PropertyChanged事件触发 } } }
}
}
|
请发表评论