DataGridViewComboBoxColumn.DataSource Eigenschaft

Definition

Ruft die Datenquelle ab, die die Auswahlmöglichkeiten für die Kombinationsfelder füllt, oder legt diese fest.

public object DataSource { get; set; }
public object? DataSource { get; set; }

Eigenschaftswert

Ein Objekt, das eine Datenquelle darstellt. Der Standardwert ist null.

Ausnahmen

Der Wert der CellTemplate-Eigenschaft ist null.

Beispiele

Im folgenden Codebeispiel wird veranschaulicht, wie Ein DataGridViewComboBoxColumn verwendet wird, um die Eingabe von Daten in die TitleOfCourtesy Spalte zu unterstützen. Die DataSource -Eigenschaft wird verwendet, um das Kombinationsfeld mit einer Auswahl von Titeln zu füllen. Dieses Beispiel ist Teil eines größeren Beispiels, das DataGridViewComboBoxColumn im Thema Klassenübersicht verfügbar ist.

private DataGridViewComboBoxColumn CreateComboBoxColumn()
{
    DataGridViewComboBoxColumn column =
        new DataGridViewComboBoxColumn();
    {
        column.DataPropertyName = ColumnName.TitleOfCourtesy.ToString();
        column.HeaderText = ColumnName.TitleOfCourtesy.ToString();
        column.DropDownWidth = 160;
        column.Width = 90;
        column.MaxDropDownItems = 3;
        column.FlatStyle = FlatStyle.Flat;
    }
    return column;
}

private void SetAlternateChoicesUsingDataSource(DataGridViewComboBoxColumn comboboxColumn)
{
    {
        comboboxColumn.DataSource = RetrieveAlternativeTitles();
        comboboxColumn.ValueMember = ColumnName.TitleOfCourtesy.ToString();
        comboboxColumn.DisplayMember = comboboxColumn.ValueMember;
    }
}

private DataTable RetrieveAlternativeTitles()
{
    return Populate("SELECT distinct TitleOfCourtesy FROM Employees");
}

string connectionString =
    "Integrated Security=SSPI;Persist Security Info=False;" +
    "Initial Catalog=Northwind;Data Source=localhost";

private DataTable Populate(string sqlCommand)
{
    SqlConnection northwindConnection = new SqlConnection(connectionString);
    northwindConnection.Open();

    SqlCommand command = new SqlCommand(sqlCommand, northwindConnection);
    SqlDataAdapter adapter = new SqlDataAdapter();
    adapter.SelectCommand = command;

    DataTable table = new DataTable();
    table.Locale = System.Globalization.CultureInfo.InvariantCulture;
    adapter.Fill(table);

    return table;
}

// Using an enum provides some abstraction between column index
// and column name along with compile time checking, and gives
// a handy place to store the column names.
enum ColumnName
{
    EmployeeId,
    LastName,
    FirstName,
    Title,
    TitleOfCourtesy,
    BirthDate,
    HireDate,
    Address,
    City,
    Region,
    PostalCode,
    Country,
    HomePhone,
    Extension,
    Photo,
    Notes,
    ReportsTo,
    PhotoPath,
    OutOfOffice
};

Hinweise

Die DataSource Eigenschaften oder Items geben an, wo die in der Dropdownliste des Kombinationsfelds angezeigten Auswahldaten abgerufen werden sollen. Wenn die Daten bei Verwendung der DataSource -Eigenschaft aus einer nicht standardmäßigen Eigenschaft oder Spalte gezeichnet werden müssen, muss die DisplayMember Eigenschaft auf den Namen der nicht standardmäßigen Eigenschaft oder Spalte festgelegt werden.

Wenn die DataSource Eigenschaft auf ein Zeichenfolgenarray ValueMember festgelegt ist, müssen und DisplayMember nicht festgelegt werden, da jede Zeichenfolge im Array sowohl für den Wert als auch für die Anzeige verwendet wird.

Durch Das Abrufen oder Festlegen dieser Eigenschaft wird die DataSource Eigenschaft des von der CellTemplate -Eigenschaft zurückgegebenen Objekts abgerufen oder festgelegt. Durch Festlegen dieser Eigenschaft wird auch die DataSource Eigenschaft jeder Zelle in der Spalte festgelegt und die Spaltenanzeige aktualisiert. Um den angegebenen Wert für einzelne Zellen zu überschreiben, legen Sie die Zellwerte fest, nachdem Sie den Spaltenwert festgelegt haben.

Gilt für:

Produkt Versionen
.NET Framework 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, 10

Weitere Informationen