3

我有一个具有主细节实现的数据网格,如下所示:

<data:DataGrid x:Name="dgData"  Width="600" ItemsSource="{Binding Path=ItemCollection}"
                       HorizontalScrollBarVisibility="Hidden" CanUserSortColumns="False" RowDetailsVisibilityChanged="dgData_RowDetailsVisibilityChanged">
                    <data:DataGrid.Columns>
                        <data:DataGridTextColumn Header="Item" Width="*" Binding="{Binding Item,Mode=TwoWay}"/>
                        <data:DataGridTextColumn Header="Company" Width="*" Binding="{Binding Company,Mode=TwoWay}"/>

                    </data:DataGrid.Columns>
                    <data:DataGrid.RowDetailsTemplate>
                        <DataTemplate>
                            <data:DataGrid x:Name="dgrdRowDetail" Width="400" AutoGenerateColumns="False" HorizontalAlignment="Center" 
                                       HorizontalScrollBarVisibility="Hidden" Grid.Row="1">
                                <data:DataGrid.Columns>
                                    <data:DataGridTextColumn Header="Date" Width="*" Binding="{Binding Date,Mode=TwoWay}"/>
                                    <data:DataGridTextColumn Header="Price" Width="*" Binding="{Binding Price, Mode=TwoWay}"/>
                                    <data:DataGridTemplateColumn>
                                        <data:DataGridTemplateColumn.CellTemplate>
                                            <DataTemplate>
                                                <Button Content="Show More Details" Click="buttonShowDetail_Click"></Button>
                                            </DataTemplate>
                                        </data:DataGridTemplateColumn.CellTemplate>
                                    </data:DataGridTemplateColumn>
                                </data:DataGrid.Columns>
                            </data:DataGrid>
                        </DataTemplate>
                    </data:DataGrid.RowDetailsTemplate>
                </data:DataGrid>

我想通过单击显示有关产品的更多详细信息的按钮打开一个子窗口。

我正在使用 MVVM 模式。我的模型包含一个将项目名称作为输入并返回详细信息数据的方法。

我的问题是我应该如何将 Item 传递给 ViewModel,它将从 Model 获取详细信息数据?我应该在哪里打开新的子窗口?在视图或视图模型中?

4

2 回答 2

5

从视图模型打开子窗口违反了模式应该是关于视图和视图模型的分离。因此,对于从何处打开子窗口,您可能没有太多选择 - 网格所在页面的代码。(这也违反了模式,但是,没有一个复杂的解决方案,这就是你能做的所有事情。)我使用 MVVM 模式,但我并不“信奉”它。当效率要求时,我会违反该模式的一些规则。

至于将项目传递给 ViewModel - 我想您可以在 ViewModel 上创建一个属性,该属性表示项目的 id。我一直在使用子窗口作为更新和添加的数据输入表单。我倾向于为它们中的每一个创建一个 ViewModel。在您的情况下,您将拥有一个表示项目详细信息的 ViewModel。会有某种与项目和详细信息相关的 ID。这将是 ViewModel 上的公共属性。您可以为将该 ID 作为参数的子窗口创建一个构造函数。然后,子窗口构造函数可以创建 ViewModel 并向其发送 ID。

像这样的东西 - 其中 DomainEdit 是子窗口的名称。

    public DomainEdit()
    {
        InitializeComponent();

        devm = new DomainEditVM();
        DataContext = devm;
    }

    public DomainEdit(Guid domainId) : this()
    {
        devm.DomainId = domainId;
        devm.GetDomain();
        txtTitle.Text = "Edit Domain";
    }

然后,从发生网格按钮单击的代码后面的代码中,您使用新的构造函数创建子窗口,传递您从网格行中的项目绑定获得的 id,并且子窗口的独立视图模型接管.

至少,这对我来说一直有效。

于 2010-06-15T18:01:04.877 回答
0

The mediator pattern (messaging service between views regarding our composite application) does the job. Furthermore, delegate the creation of the Detail View in a Child Window service and pass the selected object via the messaging service. Then you won't get any pattern violation.

于 2011-01-07T01:58:55.507 回答