wpf xaml循环遍历listview内的gridview并获取单元格值

时间:2013-06-11 07:06:14

标签: wpf xaml listview gridview

我的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);
            }
        }
    }

1 个答案:

答案 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];