Binding.UpdateSourceTrigger プロパティ
定義
重要
一部の情報は、リリース前に大きく変更される可能性があるプレリリースされた製品に関するものです。 Microsoft は、ここに記載されている情報について、明示または黙示を問わず、一切保証しません。
双方向バインディングのバインディング ソース更新のタイミングを決定する値を取得または設定します。
public:
property UpdateSourceTrigger UpdateSourceTrigger { UpdateSourceTrigger get(); void set(UpdateSourceTrigger value); };
UpdateSourceTrigger UpdateSourceTrigger();
void UpdateSourceTrigger(UpdateSourceTrigger value);
public UpdateSourceTrigger UpdateSourceTrigger { get; set; }
var updateSourceTrigger = binding.updateSourceTrigger;
binding.updateSourceTrigger = updateSourceTrigger;
Public Property UpdateSourceTrigger As UpdateSourceTrigger
<Binding UpdateSourceTrigger="updateSourceTriggerMemberName"/>
プロパティ値
UpdateSourceTrigger 値の 1 つ。 既定値は ですDefault
。これはほとんどの依存関係プロパティのPropertyChanged
更新動作として評価されますが、 プロパティの 場合とLostFocus
TextBox.Text
評価されます。
注釈
ほとんどの依存関係プロパティの既定の動作は です PropertyChanged
。 ただし、 TextBox.Text プロパティの既定の動作は です LostFocus
。
へのTextBox.Text
バインドの場合は、次のように を変更UpdateSourceTrigger
できます。
<TextBox Text="{x:Bind MyProperty, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}" />
ただし、NumberBox などの別のコントロールのコントロール テンプレートの には影響TextBox
しません。 たとえば、この UpdateSourceTrigger
設定は無効です。
<!-- This UpdateSourceTrigger setting has no effect. -->
<NumberBox Text="{x:Bind MyProperty, Mode=TwoWay, UpdateSourceTrigger=PropertyChanged}"/>
UpdateSourceTrigger 動作のもう 1 つの選択肢は、値を に設定することですExplicit
。 双方向バインディングの UpdateSourceTrigger 値が であるExplicit
場合は、関連する BindingExpression で UpdateSource を明示的に呼び出して、変更されたターゲット値でデータ ソースを更新する必要があります。
FrameworkElement.GetBindingExpression を使用して、依存関係プロパティへの Binding が存在し、そのバインドが との双方向バインディングであるオブジェクトから BindingExpression をUpdateSourceTrigger="Explicit"
取得します。
Binding オブジェクトのプロパティ値は、そのバインドがターゲット要素とターゲット プロパティにアタッチされた後は設定できません。 これを試みると、実行時例外が発生します。