UpdateSourceTrigger in WinRT

Wie met Silverlight of met WPF heeft gewerkt en MVVM regelmatig toepast zal ongetwijfeld the UpdateSourceTrigger wel is hebben aangepast. Vooral bij bindings naar een geselecteerd item is het erg handig en vaak noodzakelijk om de ingevoerde tekst bij het juiste item terug te krijgen. Helaas is de UpdateSourceTrigger weg gehaald bij WinRT.

De andere oplossing om de update te forceren van via GetBindingExpression() maar ook die is helaas niet aanwezig.

Een andere oplossing zou zijn om een eventhandler op bv TextChanged van een TextBox te implementeren. Maar ben hier niet zo fan van daar je nu buiten de binding om gaat werken, en waarom zou je dan uberhaupt nog bindings gebruiken?

 

ik heb zelf een wrapper control gemaakt:

public class BindableTextBox : TextBox
    {
        public string BindableText
        {
            get { return (string)GetValue(BindableTextProperty); }
            set { SetValue(BindableTextProperty, value); }
        }

        // Using a DependencyProperty as the backing store for BindableText.  This enables animation, styling, binding, etc...
        public static readonly DependencyProperty BindableTextProperty =
            DependencyProperty.Register("BindableText", typeof(string), typeof(BindableTextBox), new PropertyMetadata("", OnBindableTextChanged));

        private static void OnBindableTextChanged(DependencyObject sender, DependencyPropertyChangedEventArgs eventArgs)
        {
            ((BindableTextBox)sender).OnBindableTextChanged((string)eventArgs.OldValue, (string)eventArgs.NewValue);
        }

        public BindableTextBox()
        {
            TextChanged += BindableTextBox_TextChanged;
        }

        private void OnBindableTextChanged(string oldValue, string newValue)
        {
            Text = newValue ? ? string.Empty; // null is not allowed as value!
        }

        private void BindableTextBox_TextChanged(object sender, TextChangedEventArgs e)
        {
            BindableText = Text;
        }    
    }

Nu kan je tegen de nieuwe property BindableText aanbinden en word ook direct geupdate.

  •   @tfsbuck thanks
  •   @densto @VSTS see email. one just timed out but that causing the other one that was waiting got picked up directly
  •   @VSTS did you send all your build agents already for weekend?
  •   @tfsbuck already made a issue https://t.co/u0EcaMewlV
  •   @tfsbuck back again :) you guys updated tf-cli today from .11 to .13 and now getting this error when try to publish… https://t.co/GLMVwL7HDZ
  •   @jpaternotte Soort zoekt soort! Past goed tussen de andere 149 clowns
  •   @sandeepchads @VSTS in the vsts sdk they are already visible; just returning 401
  •   RT @msbotframework: LUIS and the Azure Bot Service have just hit GA! 🎉 https://t.co/QVttVKrSWe
  •   @sandeepchads @VSTS Integration with my activity feed. Are the apis already open?
  •   @tfsbuck nice i had hard time to find the reproduction path. they also fixed my issue with publishing extension. new build task coming soon!