Control.BindingContext Propriété

Définition

Obtient ou définit le BindingContext du contrôle.

[System.ComponentModel.Browsable(false)]
public virtual System.Windows.Forms.BindingContext BindingContext { get; set; }
[System.ComponentModel.Browsable(false)]
public virtual System.Windows.Forms.BindingContext? BindingContext { get; set; }

Valeur de propriété

BindingContext du contrôle.

Implémente

Attributs

Exemples

L’exemple de code suivant crée quatre Binding objets pour lier cinq contrôles, un DateTimePicker et quatre TextBox contrôles, à plusieurs sources de données. Le BindingContext est ensuite utilisé pour obtenir le BindingManagerBase pour chaque source de données.

protected void BindControls()
{
   /* Create two Binding objects for the first two TextBox 
      controls. The data-bound property for both controls 
      is the Text property. The data source is a DataSet 
      (ds). The data member is a navigation path in the form: 
      "TableName.ColumnName". */
   text1.DataBindings.Add(new Binding
   ("Text", ds, "customers.custName"));
   text2.DataBindings.Add(new Binding
   ("Text", ds, "customers.custID"));
   
   /* Bind the DateTimePicker control by adding a new Binding. 
      The data member of the DateTimePicker is a navigation path:
      TableName.RelationName.ColumnName string. */
   DateTimePicker1.DataBindings.Add(new 
   Binding("Value", ds, "customers.CustToOrders.OrderDate"));

   /* Add event delegates for the Parse and Format events to a 
      new Binding object, and add the object to the third 
      TextBox control's BindingsCollection. The delegates 
      must be added before adding the Binding to the 
      collection; otherwise, no formatting occurs until 
      the Current object of the BindingManagerBase for 
      the data source changes. */
      Binding b = new Binding
      ("Text", ds, "customers.custToOrders.OrderAmount");
   b.Parse+=new ConvertEventHandler(CurrencyStringToDecimal);
   b.Format+=new ConvertEventHandler(DecimalToCurrencyString);
   text3.DataBindings.Add(b);

   // Get the BindingManagerBase for the Customers table. 
   bmCustomers = this.BindingContext [ds, "Customers"];

   /* Get the BindingManagerBase for the Orders table using the 
      RelationName. */ 
   bmOrders = this.BindingContext[ds, "customers.CustToOrders"];

   /* Bind the fourth TextBox control's Text property to the
   third control's Text property. */
   text4.DataBindings.Add("Text", text3, "Text");
}

Remarques

Le BindingContext d’un Control est utilisé pour retourner un unique BindingManagerBase pour tous les contrôles liés aux données contenus par le Control. Le BindingManagerBase conserve synchronisé tous les contrôles liés à la même source de données. Par exemple, la définition de la Position propriété du BindingManagerBase spécifie l’élément dans la liste sous-jacente vers laquelle tous les contrôles liés aux données pointent.

Pour plus d’informations sur la création d’un nouveau BindingContext et son affectation à la BindingContext propriété, consultez .BindingContext

Notes pour les héritiers

Lorsque vous substituez la BindingContext propriété dans une classe dérivée, utilisez la propriété de la classe de BindingContext base pour étendre l’implémentation de base. Sinon, vous devez fournir toute l’implémentation. Vous n’êtes pas obligé de remplacer les get accesseurs et set de la BindingContext propriété ; vous ne pouvez remplacer qu’un seul si nécessaire.

S’applique à

Produit Versions
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9

Voir aussi