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:
Se a fonte de dados não implementar IBindingListo e, portanto, gerar ListChanged eventos do tipo ItemChanged.
Se a fonte de IEditableObjectdados implementar o .
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
.NET Desktop feedback