Observação
O acesso a essa página exige autorização. Você pode tentar entrar ou alterar diretórios.
O acesso a essa página exige autorização. Você pode tentar alterar os diretórios.
Durante a implementação da associação de dados no Windows Forms, vários controles são associados à mesma fonte de dados. Nas seguintes situações, é necessário garantir que as propriedades associadas do controle permaneçam sincronizadas entre si e com a fonte de dados:
Se a fonte de dados não implementa IBindingList e, portanto, gera eventos ListChanged do tipo ItemChanged.
Se a fonte de dados implementa IEditableObject.
No caso anterior, você pode usar um BindingSource para associar a fonte de dados aos controles. No último caso, você usa um BindingSource para manipular o evento BindingComplete e, em seguida, chama EndCurrentEdit no BindingManagerBase associado.
Exemplo de controles de associação usando BindingSource
O exemplo de código a seguir demonstra como associar três controles, dois controles de caixa de texto e um controle DataGridView à mesma coluna em um DataSet usando um componente BindingSource. O exemplo demonstra como lidar com o evento BindingComplete. Ele garante que, quando o valor de texto de uma caixa de texto é alterado, a outra caixa de texto e o controle DataGridView são atualizados com o valor correto.
O exemplo usa um BindingSource para associar a fonte de dados e os controles. Como alternativa, você pode associar os controles diretamente à fonte de dados e recuperar o BindingManagerBase para a associação do BindingContext do formulário e, em seguida, manipular o evento BindingComplete para o BindingManagerBase. Para obter mais informações sobre como associar a fonte de dados e os controles, consulte a página de ajuda sobre o evento BindingComplete 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
Consulte também
.NET Desktop feedback