[英]Databind ADO.NET Entity Framework to ListBox
我正在嘗試將ADO EF對象類(材料)附加到ListBox,並在將新材料添加到數據庫時使其自動更新。
在下面的當前代碼中,它將顯示在設置控件數據源之前數據庫中的所有項目,但不會更新。
我知道我在這里缺少基本知識。 任何幫助是極大的贊賞!
public partial class Main : KryptonForm
{
private AGAEntities db = new AGAEntities();
public Main()
{
InitializeComponent();
}
private void Main_Load(object sender, EventArgs e)
{
matList.DataSource = db.Materials;
matList.DisplayMember = "Name";
}
private void newMat_Click(object sender, EventArgs e)
{
AddMaterial form = new AddMaterial();
form.ShowDialog();
}
}
這是因為db.Materials
在添加項目時不會引發通知。 您應該使用BindingList<T>
作為DataSource
:
private BindingList<Material> _materials;
private void Main_Load(object sender, EventArgs e)
{
_materials = new BindingList<Material>(db.Materials);
matList.DataSource = _materials;
matList.DisplayMember = "Name";
}
private void newMat_Click(object sender, EventArgs e)
{
AddMaterial form = new AddMaterial();
if (form.ShowDialog() == DialogResult.OK)
{
_materials.Add(form.NewMaterial);
}
}
(此代碼假定您的AddMaterial
類將新項目添加到數據庫中,並通過NewMaterial
屬性公開它)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.