Compartilhar via


Sincronizar vários controles com a mesma fonte de dados (Windows Forms .NET)

Durante a implementação da vinculação de dados no Windows Forms, vários controles são vinculados à mesma fonte de dados. Nas seguintes situações, é necessário garantir que as propriedades vinculadas do controle permaneçam sincronizadas entre si e com a fonte de dados:

No primeiro caso, você pode usar um para vincular a fonte de BindingSource dados aos controles. No último caso, você usa um BindingSource e manipula o evento e chama EndCurrentEdit o BindingCompleteBindingManagerBase.

Exemplo de controles bind usando BindingSource

O exemplo de código a seguir demonstra como vincular três controles, dois controles de caixa de texto e um controle para a mesma coluna em um usando um DataGridViewDataSetBindingSource componente. O exemplo demonstra como manipular o BindingComplete evento. Ele garante que quando o valor de texto de uma caixa de texto é alterado, a outra caixa de texto e o controle são atualizados com o DataGridView valor correto.

O exemplo usa a para vincular a fonte de BindingSource dados e os controles. Como alternativa, você pode vincular os controles diretamente à fonte de dados e recuperar o para a associação do formulário e, em seguida, manipular o evento para o BindingManagerBaseBindingCompleteBindingManagerBase.BindingContext Para obter mais informações sobre como vincular a fonte de dados e os controles, consulte a página de ajuda sobre o BindingComplete evento de BindingManagerBase.

public Form1() 
{
    InitializeComponent();
    set1.Tables.Add("Menu");
    set1.Tables[0].Columns.Add("Beverages");

    // Add some rows to the table.
    set1.Tables[0].Rows.Add("coffee");
    set1.Tables[0].Rows.Add("tea");
    set1.Tables[0].Rows.Add("hot chocolate");
    set1.Tables[0].Rows.Add("milk");
    set1.Tables[0].Rows.Add("orange juice");

    // Set the data source to the DataSet.
    bindingSource1.DataSource = set1;

    //Set the DataMember to the Menu table.
    bindingSource1.DataMember = "Menu";

    // Add the control data bindings.
    dataGridView1.DataSource = bindingSource1;
    textBox1.DataBindings.Add("Text", bindingSource1,
        "Beverages", true, DataSourceUpdateMode.OnPropertyChanged);
    textBox2.DataBindings.Add("Text", bindingSource1,
        "Beverages", true, DataSourceUpdateMode.OnPropertyChanged);
    bindingSource1.BindingComplete +=
        new BindingCompleteEventHandler(bindingSource1_BindingComplete);
}

void bindingSource1_BindingComplete(object sender, BindingCompleteEventArgs e)
{
    // Check if the data source has been updated, and that no error has occurred.
    if (e.BindingCompleteContext ==
        BindingCompleteContext.DataSourceUpdate && e.Exception == null)

        // If not, end the current edit.
        e.Binding.BindingManagerBase.EndCurrentEdit();
}
Public Class Form1
    Private Sub InitializeControlsAndDataSource()
        ' Add a table and column to DataSet.
        set1.Tables.Add("Menu")
        set1.Tables(0).Columns.Add("Beverages")

        ' Add some rows to the table.
        set1.Tables(0).Rows.Add("coffee")
        set1.Tables(0).Rows.Add("tea")
        set1.Tables(0).Rows.Add("hot chocolate")
        set1.Tables(0).Rows.Add("milk")
        set1.Tables(0).Rows.Add("orange juice")

        ' Set the data source to the DataSet.
        BindingSource1.DataSource = set1

        'Set the DataMember to the Menu table.
        BindingSource1.DataMember = "Menu"

        ' Add the control data bindings.
        DataGridView1.DataSource = BindingSource1
        TextBox1.DataBindings.Add("Text", BindingSource1, "Beverages",
            True, DataSourceUpdateMode.OnPropertyChanged)
        TextBox2.DataBindings.Add("Text", BindingSource1, "Beverages",
            True, DataSourceUpdateMode.OnPropertyChanged)
    End Sub

    Private Sub BindingSource1_BindingComplete(ByVal sender As Object,
        ByVal e As BindingCompleteEventArgs) Handles BindingSource1.BindingComplete

        ' Check if the data source has been updated, and that no error has occurred.
        If e.BindingCompleteContext = BindingCompleteContext.DataSourceUpdate _
            AndAlso e.Exception Is Nothing Then

            ' If not, end the current edit.
            e.Binding.BindingManagerBase.EndCurrentEdit()
        End If
    End Sub
        
    Private Sub Form1_Load(sender As Object, e As EventArgs) Handles MyBase.Load
        InitializeControlsAndDataSource()
    End Sub
End Class

Confira também