我的dgridtext.xaml文件中包含以下内容。
XAML
<Grid x:Name="grid1">
<StackPanel>
<ListView Name="listview1" IsTextSearchEnabled="True" TextSearch.TextPath="Enquiry_Number">
<ListView.View>
<GridView ColumnHeaderToolTip="Multiple Category Information">
<GridViewColumn DisplayMemberBinding="{Binding Path=Enquiry_Number}" Header="Enquiry number"/>
<GridViewColumn DisplayMemberBinding="{Binding Path=Consignee_Ref}" Header="Consignee reference"/>
<GridViewColumn DisplayMemberBinding="{Binding Path=Booking_Reference}" Header="Booking reference"/>
</GridView>
</ListView.View>
</ListView>
</StackPanel>
</Grid>
像这样。
dgridtest.xaml.cs
for (int i = 0; i < listview1.Items.Count; i++)
{
MessageBox.Show(listview1.Items[i].ToString());
}
但是返回的只是System.Data.DataRowView
请帮忙。
更新
在我的dgridtextxaml.cs文件中,我调用DataManager.cs类传递一个数据集对象,该对象是我的listview(listview1)的源。
DataManager.BindFilteredData(dts);
listview1.ItemsSource = dts.Tables[0].DefaultView;
这就是我在DataManager.cs类中的内容
public static void BindFilteredData(DataSet dts)
{
using (SqlConnection connection = new SqlConnection(ConfigurationManager.ConnectionStrings["ConString"].ConnectionString))
{
string sql = "SELECT Enquiry_Number, Consignee_Ref, Booking_Reference FROM ConsHead";
using (SqlDataAdapter adapter = new SqlDataAdapter(sql, connection))
{
adapter.Fill(dts);
}
}
}
答案 0 :(得分:2)
您可以将项目强制转换为ListView中使用的任何类,然后使用您需要的任何属性。类似的东西:
var item = listView1.Items[i] as YourClassHere;
修改强>
在您的情况下,由于您直接将ItemsSource绑定到DataSet,您可能可以使用DataRowView类,然后使用它的属性:
var firstItem = listview1.Items[0] as DataRowView;
var firstCellValue = firstItem.Row[0];