Procedura: associare un controllo Windows Form a un tipo
Quando si compilano controlli che interagiscono con dati, è a volte necessario associare un controllo a un tipo anziché a un oggetto. La situazione si presenta soprattutto in fase di progettazione, quando i dati potrebbero non essere disponibili mentre per i controlli associati a dati è necessario visualizzare informazioni da un'interfaccia pubblica di un tipo. È possibile, ad esempio, associare un controllo DataGridView a un oggetto esposto da un servizio Web e far sì che il controllo DataGridView etichetti le colonne in fase di progettazione con i nomi dei membri di un tipo personalizzato.
È possibile associare facilmente un controllo a un tipo utilizzando il componente BindingSource.
Esempio
Nell'esempio di codice seguente viene illustrato come associare un controllo DataGridView a un tipo personalizzato mediante un componente BindingSource. Quando si esegue l'esempio, si noterà che il controllo DataGridView ha etichettato le colonne che riflettono le proprietà di un oggetto Customer, prima che il controllo venga popolato con i dati. Nell'esempio viene utilizzato il pulsante Aggiungi cliente per aggiungere i dati al controllo DataGridView. Quando si fa clic sul pulsante, un nuovo oggetto Customer viene aggiunto al controllo BindingSource. In un scenario reale, i dati potrebbero essere ottenuti da una chiamata a un servizio Web o a un'altra origine dati.
Imports System
Imports System.Collections.Generic
Imports System.ComponentModel
Imports System.Data
Imports System.Drawing
Imports System.Windows.Forms
Class Form1
Inherits Form
Private bSource As New BindingSource()
Private WithEvents button1 As Button
Private dgv As New DataGridView()
Public Sub New()
Me.button1 = New System.Windows.Forms.Button()
Me.button1.Location = New System.Drawing.Point(140, 326)
Me.button1.Name = "button1"
Me.button1.AutoSize = True
Me.button1.Text = "Add Customer"
Me.ClientSize = New System.Drawing.Size(362, 370)
Me.Controls.Add(Me.button1)
' Bind the BindingSource to the DemoCustomer type.
bSource.DataSource = GetType(DemoCustomer)
' Set up the DataGridView control.
dgv.Dock = DockStyle.Top
Me.Controls.Add(dgv)
' Bind the DataGridView control to the BindingSource.
dgv.DataSource = bSource
End Sub
Public Shared Sub Main()
Application.Run(New Form1())
End Sub
Private Sub button1_Click(ByVal sender As Object, ByVal e As EventArgs) _
Handles button1.Click
bSource.Add(New DemoCustomer(DateTime.Today))
End Sub
End Class
' This simple class is used to demonstrate binding to a type.
Public Class DemoCustomer
Public Sub New()
idValue = Guid.NewGuid()
End Sub
Public Sub New(ByVal FirstOrderDate As DateTime)
FirstOrder = FirstOrderDate
idValue = Guid.NewGuid()
End Sub
' These fields hold the data that backs the public properties.
Private firstOrderDateValue As DateTime
Private idValue As Guid
Private custNameValue As String
Public Property CustomerName() As String
Get
Return custNameValue
End Get
Set(ByVal value As String)
custNameValue = value
End Set
End Property
' This is a property that represents the first order date.
Public Property FirstOrder() As DateTime
Get
Return Me.firstOrderDateValue
End Get
Set(ByVal value As DateTime)
If value <> Me.firstOrderDateValue Then
Me.firstOrderDateValue = value
End If
End Set
End Property
' This is a property that represents a customer ID.
Public ReadOnly Property ID() As Guid
Get
Return Me.idValue
End Get
End Property
End Class
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Windows.Forms;
class Form1 : Form
{
BindingSource bSource = new BindingSource();
private Button button1;
DataGridView dgv = new DataGridView();
public Form1()
{
this.button1 = new System.Windows.Forms.Button();
this.button1.Location = new System.Drawing.Point(140, 326);
this.button1.Name = "button1";
this.button1.AutoSize = true;
this.button1.Text = "Add Customer";
this.button1.Click += new System.EventHandler(this.button1_Click);
this.ClientSize = new System.Drawing.Size(362, 370);
this.Controls.Add(this.button1);
// Bind the BindingSource to the DemoCustomer type.
bSource.DataSource = typeof(DemoCustomer);
// Set up the DataGridView control.
dgv.Dock = DockStyle.Top;
this.Controls.Add(dgv);
// Bind the DataGridView control to the BindingSource.
dgv.DataSource = bSource;
}
public static void Main()
{
Application.Run(new Form1());
}
private void button1_Click(object sender, EventArgs e)
{
bSource.Add(new DemoCustomer(DateTime.Today));
}
}
// This simple class is used to demonstrate binding to a type.
public class DemoCustomer
{
public DemoCustomer()
{
idValue = Guid.NewGuid();
}
public DemoCustomer(DateTime FirstOrderDate)
{
FirstOrder = FirstOrderDate;
idValue = Guid.NewGuid();
}
// These fields hold the data that backs the public properties.
private DateTime firstOrderDateValue;
private Guid idValue;
private string custNameValue;
public string CustomerName
{
get { return custNameValue; }
set { custNameValue = value; }
}
// This is a property that represents a birth date.
public DateTime FirstOrder
{
get
{
return this.firstOrderDateValue;
}
set
{
if (value != this.firstOrderDateValue)
{
this.firstOrderDateValue = value;
}
}
}
// This is a property that represents a customer ID.
public Guid ID
{
get
{
return this.idValue;
}
}
}
Compilazione del codice
Per questo esempio sono necessari i seguenti requisiti:
- Riferimenti agli assembly System e System.Windows.Forms.
Per informazioni sulla compilazione di questo esempio dalla riga di comando per Visual Basic o Visual C#, vedere Building from the Command Line (Visual Basic) o Compilazione dalla riga di comando con csc.exe. È anche possibile compilare questo esempio in Visual Studio incollando il codice in un nuovo progetto. Per ulteriori informazioni, vedere Procedura: compilare ed eseguire un esempio di codice Windows Form completo tramite Visual Studio e Procedura: compilare ed eseguire un esempio di codice Windows Form completo tramite Visual Studio e Procedura: compilare ed eseguire un esempio di codice Windows Form completo tramite Visual Studio e Procedura: compilare ed eseguire un esempio di codice Windows Form completo tramite Visual Studio e Procedura: compilare ed eseguire un esempio di codice Windows Form completo tramite Visual Studio.