Binding.Format Gebeurtenis
Definitie
Belangrijk
Bepaalde informatie heeft betrekking op een voorlopige productversie die aanzienlijk kan worden gewijzigd voordat deze wordt uitgebracht. Microsoft biedt geen enkele expliciete of impliciete garanties met betrekking tot de informatie die hier wordt verstrekt.
Treedt op wanneer de eigenschap van een besturingselement is gebonden aan een gegevenswaarde.
public:
event System::Windows::Forms::ConvertEventHandler ^ Format;
public event System.Windows.Forms.ConvertEventHandler Format;
member this.Format : System.Windows.Forms.ConvertEventHandler
Public Custom Event Format As ConvertEventHandler
Gebeurtenistype
Voorbeelden
In het volgende codevoorbeeld wordt een BindingConvertEventHandler gemachtigde aan zowel de als Format de Parse gebeurtenissen toegevoegd en wordt het Binding aan een BindingsCollectionTextBox besturingselement toegevoegd via de DataBindings eigenschap. De DecimalToCurrencyString gebeurtenisdelegatie, toegevoegd aan de Format gebeurtenis, maakt de afhankelijke waarde (een Decimal type) op als valuta met behulp van de ToString methode. De CurrencyStringToDecimal gedelegeerde van de gebeurtenis, toegevoegd aan de Parse gebeurtenis, converteert de waarde die door het besturingselement wordt weergegeven terug naar het Decimal type.
In dit voorbeeld wordt ervan uitgegaan dat een DataSet benoemde dsnaam aanwezig is.
private:
void DecimalToCurrencyString( Object^ /*sender*/, ConvertEventArgs^ cevent )
{
// The method converts only to string type. Test this using the DesiredType.
if ( cevent->DesiredType != String::typeid )
{
return;
}
// Use the ToString method to format the value as currency ("c").
cevent->Value = ( (Decimal)(cevent->Value) ).ToString( "c" );
}
void CurrencyStringToDecimal( Object^ /*sender*/, ConvertEventArgs^ cevent )
{
// The method converts back to decimal type only.
if ( cevent->DesiredType != Decimal::typeid )
{
return;
}
// Converts the string back to decimal using the static Parse method.
cevent->Value = Decimal::Parse( cevent->Value->ToString(),
NumberStyles::Currency, nullptr );
}
void BindControl()
{
// Creates the binding first. The OrderAmount is a Decimal type.
Binding^ b = gcnew Binding(
"Text",ds,"customers.custToOrders.OrderAmount" );
// Add the delegates to the event.
b->Format += gcnew ConvertEventHandler( this, &Form1::DecimalToCurrencyString );
b->Parse += gcnew ConvertEventHandler( this, &Form1::CurrencyStringToDecimal );
text1->DataBindings->Add( b );
}
private void DecimalToCurrencyString(object sender, ConvertEventArgs cevent)
{
// The method converts only to string type. Test this using the DesiredType.
if(cevent.DesiredType != typeof(string)) return;
// Use the ToString method to format the value as currency ("c").
cevent.Value = ((decimal) cevent.Value).ToString("c");
}
private void CurrencyStringToDecimal(object sender, ConvertEventArgs cevent)
{
// The method converts back to decimal type only.
if(cevent.DesiredType != typeof(decimal)) return;
// Converts the string back to decimal using the static Parse method.
cevent.Value = Decimal.Parse(cevent.Value.ToString(),
NumberStyles.Currency, null);
}
private void BindControl()
{
// Creates the binding first. The OrderAmount is a Decimal type.
Binding b = new Binding
("Text", ds, "customers.custToOrders.OrderAmount");
// Add the delegates to the event.
b.Format += new ConvertEventHandler(DecimalToCurrencyString);
b.Parse += new ConvertEventHandler(CurrencyStringToDecimal);
text1.DataBindings.Add(b);
}
Private Sub DecimalToCurrencyString(sender As Object, cevent As _
ConvertEventArgs)
' The method converts only to string type. Test this using the DesiredType.
If cevent.DesiredType IsNot GetType(String) Then
Exit Sub
End If
' Use the ToString method to format the value as currency ("c").
cevent.Value = CType(cevent.Value, Decimal).ToString("c")
End Sub
Private Sub CurrencyStringToDecimal(sender As Object, cevent As _
ConvertEventArgs)
' The method converts back to decimal type only.
If cevent.DesiredType IsNot GetType(Decimal) Then
Exit Sub
End If
' Converts the string back to decimal using the static ToDecimal method.
cevent.Value = Decimal.Parse(cevent.Value.ToString, _
NumberStyles.Currency, nothing)
End Sub
Private Sub BindControl
' Creates the binding first. The OrderAmount is a Decimal type.
Dim b As Binding = New Binding _
("Text", ds, "customers.custToOrders.OrderAmount")
' Add the delegates to the event
AddHandler b.Format, AddressOf DecimalToCurrencyString
AddHandler b.Parse, AddressOf CurrencyStringToDecimal
text1.DataBindings.Add(b)
End Sub
Opmerkingen
De Format gebeurtenis wordt gegenereerd wanneer gegevens vanuit de gegevensbron naar het besturingselement worden gepusht. U kunt de Format gebeurtenis afhandelen om niet-opgemaakte gegevens uit de gegevensbron te converteren naar opgemaakte gegevens voor weergave. Wanneer gegevens worden opgehaald uit het besturingselement in de gegevensbron, wordt de Parse gebeurtenis gegenereerd om de weergegeven waarde op te maken en treedt de Format gebeurtenis op om de gegevens opnieuw op te maken voor weergave. Dit zorgt ervoor dat met het afhankelijke besturingselement correct opgemaakte gegevens worden weergegeven, ongeacht of de gebruiker opgemaakte of niet-opgemaakte gegevens invoert in het besturingselement.
Met de Format en Parse gebeurtenissen kunt u aangepaste indelingen maken voor het weergeven van gegevens. Als de gegevens in een tabel bijvoorbeeld van het type Decimalzijn, kunt u de gegevens weergeven in de lokale valuta-indeling door de eigenschap van de ValueConvertEventArgs waarde in te stellen op de opgemaakte waarde in de Format gebeurtenis. Daarom moet u de weergegeven waarde in de Parse gebeurtenis opheffen.
De Format gebeurtenis vindt plaats wanneer de Current waarde van de BindingManagerBase wijzigingen, waaronder:
De eerste keer dat de eigenschap is gebonden.
Telkens wanneer de Position wijzigingen zijn doorgevoerd.
Wanneer de gegevensgebonden lijst wordt gesorteerd of gefilterd, wat wordt bereikt wanneer een DataView lijst wordt geleverd.
De Format gebeurtenis vindt ook plaats na de Parse gebeurtenis. Wanneer een besturingselement bijvoorbeeld de focus verliest, wordt de inhoud geparseerd. Direct daarna, wanneer nieuwe gegevens naar het besturingselement worden gepusht, treedt de Format gebeurtenis op zodat de nieuwe inhoud kan worden opgemaakt.
Zie Gebeurtenissen verwerken en genereren voor meer informatie over het afhandelen van gebeurtenissen.