像往常一样,我做了一点研究,但无法在网站或其他地方找到答案。如果你能指点我一个存在的问题,我会很感激。否则,这里是问题:ListView不会更新,尽管绑定到DataTable
我有一个ListView
对象绑定到一个DataTable
对象。请参见下面的定义:
<ListView Name="MyList">
<ListView.View>
<GridView>
<GridViewColumn x:Name="Column1Name" DisplayMemberBinding="{Binding Path=Column1}" />
<GridViewColumn x:Name="Column2Name" DisplayMemberBinding="{Binding Path=Column2}" />
<GridViewColumn x:Name="Column3Name" DisplayMemberBinding="{Binding Path=Column3}" />
<GridViewColumn x:Name="Column4Name" DisplayMemberBinding="{Binding Path=Column4}" />
</GridView>
</ListView.View>
</ListView>
绑定代码如下:
DataTable items = new DataTable();
items = DatabaseService.GetMyItems(20, true, items);
Binding binding = new Binding();
binding.Source = items.DefaultView;
binding.Mode = BindingMode.OneWay;
MyList.SetBinding(ListView.ItemsSourceProperty, binding);
执行查询是如下的实际代码:
/** Parameters: commandText = <sql>, table = items */
using (DbConnection connection = new SqlConnection(Project.Properties.Settings.Default.ConnectionString))
{
using (DbCommand command = connection.CreateCommand())
{
command.CommandText = commandText;
command.CommandType = CommandType.Text;
using (DbDataAdapter dataAdapter = new SqlDataAdapter())
{
dataAdapter.SelectCommand = command;
dataAdapter.Fill(table);
}
}
}
此代码工作第一次,但当我在数据更改后再次调用GetMyItems
方法时,数据不刷新。
我在做什么错?
DataTable已经在.Net框架API(使用4.0)-'System.Data.DataTable'中。可观察列表属性是'Datatable.DefaultView'有一个名为'ListChanged'的事件([link here](http://msdn.microsoft.com/en-us/library/system.data.dataview(v = vs.100 )的.aspx))。 – Sinker
@Sinker没关系。看我的编辑。 –