避免在datacontext中使用匿名类型?

时间:2012-08-14 20:17:24

标签: c# wpf linq xaml datagrid

我有这个数据网格

<DataGrid Grid.Row="3" Name="DataGrid6S" AutoGenerateColumns="False" VerticalScrollBarVisibility="Auto">
    <DataGrid.Columns>
    <DataGridTextColumn Header="ID" Width="50" Binding="{Binding ID}" Visibility="Collapsed"></DataGridTextColumn>
        <DataGridTextColumn Header="Name" Width="200" Binding="{Binding Name}"></DataGridTextColumn>
        <DataGridTextColumn Header="Text" Width="200" Binding="{Binding Text}"></DataGridTextColumn>
        <DataGridTemplateColumn Header="Edit" Width="*">
            <DataGridTemplateColumn.CellTemplate>
                <DataTemplate>
                    <Button Click="Button_Click" >View Details</Button>
                </DataTemplate>
            </DataGridTemplateColumn.CellTemplate>
        </DataGridTemplateColumn>
    </DataGrid.Columns>
</DataGrid>

由以下代码填充:

class Test {
        public int W { get; set; }
        public string X { get; set; }
        public string Y { get; set; }
    }

public partial class MainWindow : Window {
    public MainWindow() {
        InitializeComponent();

        List<Test> testList = new List<Test>();
        testList.Add(new Test() { W = 0, X = "hello", Y = "one" });
        testList.Add(new Test() { W = 1, X = "hello", Y = "two" });
        testList.Add(new Test() { W = 2, X = "hello", Y = "three" });
        testList.Add(new Test() { W = 3, X = "hello", Y = "four" });

        var query =
            from values in testList
            select new { ID = values.W, Name = values.X, Text = values.Y };

        DataGrid6S.ItemsSource = query;

    }

    private void Button_Click(object sender, RoutedEventArgs e) {
        var obj = ((FrameworkElement)sender).DataContext;
        // Can't access values because it's of an anoymous type.
        // What do I have to do to be able to access the values stored here?

    }
}

当点击一个按钮时,我想知道点击该按钮的行的ID,但我找不到因为行是用匿名类型初始化的,我该怎么办呢找出点击的行的ID?

注意:这是一个简化版本,假设查询包含5个连接和&amp;一个where子句。

2 个答案:

答案 0 :(得分:0)

为什么要在查询中使用匿名类型?您已经有了一个很好的对象,可以按照您所拥有的格式保存您需要的所有数据。通过将其转换为匿名查询,您可以显式删除所有有用的信息。只需将testList设置为数据源,然后在按钮单击中访问Test项。

答案 1 :(得分:0)

只需创建一个命名类型并选择其实例,匿名类型适用于仅在创建它们的范围内编辑的对象。另外为什么不直接使用Test类?唯一的区别是属性名称。另外,请不要忘记将DataContext转换为您的命名类型,因为它是object