zoukankan      html  css  js  c++  java
  • UpdateSourceTrigger Property in WPF Binding

    介绍

    这篇文章我将介绍在WPF和Silverlight中更新绑定源的概念。正如您所知道的,当我们用TwoWay的模式绑定时,任何在目标控件上发生的变化都会影响绑定源的值。

    请注意只是在用TwoWay绑定的时候,而不是默认的绑定模式OneWay或者OneTime。

    现在,问题是当更新源数据时,由于目标控件的数据发生的变化。实际上有三个方法可以实现。

      • Default: 由不同控件控制. 例如 TextBox, 当 LostFocus 事件触发时,目标绑定发生变化.
      • PropertyChanged: 意味着当目标控件值发生变化时,源数据立马更新.例如, TextBox是目标绑定,当输入字符时, 源数据也发生变化. 着就意味着当你输入字符创的时候,TextBox的数据Text也在改变.
      • Explicit: 当UpdateSourceTrigger 设置为 Explicit, 数据源不会自动更新,只有在后代码里面显示的触发。 

     

    针对这些方法我写啦一些代码帮助你们更好的理解他们.我们首先从 default 开始. 看下面的代码块:

     1 <Border BorderThickness="2" Margin="0 20 0 0" BorderBrush="Brown" CornerRadius="5">
     2     <StackPanel>
     3         <TextBox x:Name="textInput2" Margin="5" />
     4         <TextBox x:Name="txtOutput2" Margin="5"
     5                          Text="{Binding Text,
     6                                 ElementName=textInput2,
     7                                 UpdateSourceTrigger=Default,
     8                                 Mode=TwoWay}"/>
     9     </StackPanel>
    10 </Border>

    这里有一个Border元素里面有一个StackPanel里面包含两个TextBox.第二个TextBox的Text属性绑定啦第一个TextBox的属性Text.在所有的例子里面实际上还有一些代码. 这个绑定的Mode 设置为 TwoWay 因为我们想更新源数据无论目标发生变化的时候. 最后, 绑定的属性UpdateSourceTrigger被设置为 Default. 这就意味着当第二个TextBox的绑定目标丢失焦点或者触发LostFocus 事件时,第一个TextBox的属性Text绑定的源数据会被更新。

    第二个例子是设置 UpdateSourceTrigger 为PropertyChanged.

     1 <Border BorderThickness="2" BorderBrush="Brown" CornerRadius="5">
     2     <StackPanel>
     3         <TextBox x:Name="textInput1" Margin="5" />
     4         <TextBox x:Name="txtOutput1" Margin="5" 
     5                          Text="{Binding Text,
     6                                 ElementName=textInput1,
     7                                 UpdateSourceTrigger=PropertyChanged,
     8                                 Mode=TwoWay}"/>
     9     </StackPanel>
    10 </Border>

    这个代码块和第二个相比唯一不同的是 UpdateSourceTrigger 被设置为 PropertyChanged. 正如这个名字暗示的, 这就意味着无论何时第二个TextBox的Text属性发生变化时,第一个TextBox的属性Text立马被更新。

    最后,我们最后的例子是将属性 UpdateSourceTrigger 设置为 Explicit.

     1 <Border BorderThickness="2" Margin="0 20 0 0" BorderBrush="Brown" CornerRadius="5">
     2     <StackPanel>
     3         <TextBox x:Name="textInput3" Margin="5" />
     4         <TextBox x:Name="txtOutput3" Margin="5" 
     5                          Text="{Binding Text,
     6                                 ElementName=textInput3,
     7                                 UpdateSourceTrigger=Explicit,
     8                                 Mode=TwoWay}"/>
     9         <Button Content="Save" Click="Button_Click"/>
    10     </StackPanel>
    11 </Border>

    不同的东西在这段代码是UpdateSourceTrigger设置为Explicit。正如我们前面所说,这意味着更新过程不会发生,除非你做到明确操作。这个Button 被声明在第二个TextBox后面负责做明确操作。正如你可能已经注意到,有一个EventHandler对它的点击事件Clickevent,,下面几行代码都写在那EventHandler里。

    1 private void Button_Click(object sender, RoutedEventArgs e)
    2 {
    3     BindingExpression be = txtOutput3.GetBindingExpression(TextBox.TextProperty);
    4     be.UpdateSource();
    5 }

    BindingExpression类声明一个实例。在那之后,txtOutput3获取TextBox.TextProperty的绑定表达式放在那个实例里。最后,UpdateSource方法的是被称为明确的更新绑定源。

     代码下载地址:http://www.codeproject.com/Articles/507883/UpdateSourceTrigger-Property-in-WPF-Binding

  • 相关阅读:
    js将数字转为千分位/清除千分位
    mybatis中的$和#的区别
    js处理title超长问题
    mybatis错误 Mapped Statements collection does not contain value for
    bootstrap添加多个模态对话框支持
    java.util.Collections.copy()方法注意点
    list通过比较器进行排序
    jquery对radio和checkbox的操作
    c++类简介
    c++ 类
  • 原文地址:https://www.cnblogs.com/kissfu/p/3230080.html
Copyright © 2011-2022 走看看