Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Clearing Textbox does not set binding to null

I am having difficulty setting an empty TextBox to null on an nullable DB Field.

XAML

<y:TextBox Text="{Binding Year1Cost, Mode=TwoWay,  
     UpdateSourceTrigger=PropertyChanged,   
     NotifyOnValidationError=True,   
     ValidatesOnDataErrors=True,   
     ValidatesOnExceptions=True,  
     StringFormat=\{0:c\}}" Grid.Row="3" Grid.Column="1" />

When I enter any value into it the binding is fine and the entered value is passed
When I leave a null value alone a null is passed
If I delete the value from the TextBox the value passed is the Original value of the Textbox and the UI is not notified of the change Grrrrrrrrrrrrrrrr

I have spent a long time checking out options nothing short of putting code behind the OnTextChanged of every nullable field I cannot see the efficiency in doing this.

Thanks in advance:

ps. Have looked at TargetNullValue to no success

Visual Studio 2008 - SP1 - .Net 3.5

like image 510
Traci Avatar asked Jan 14 '10 07:01

Traci


2 Answers

Set the property TargetNullValue of the binding to String.Empty:

<TextBox Text="{Binding TargetNullValue={x:Static sys:String.Empty}}"/>

I tried it and it works for me.

And if I am not wrong (please forgive me if I am), you should set the property StringFormat like this:

StringFormat={}{0:C}

This is even probably the reason of the exception you got.

like image 147
Shimmy Weitzhandler Avatar answered Dec 04 '22 08:12

Shimmy Weitzhandler


Consider using a value converter. You should be able to implement the ConvertBack method to translate empty strings into nulls.

like image 34
itowlson Avatar answered Dec 04 '22 09:12

itowlson