1

WPF xaml ページで、2 つのオプションがある 1 つのコンボボックスをユーザーに提供したいと考えています。

(1) ユーザーがグリッドビューで編集できるようにする (2) ユーザーがフォームで編集できるようにする

ユーザーが最初のオプションを選択した場合、ユーザーは gridview 自体でレコードの追加/編集を許可する必要があります。

ユーザーが 2 番目のオプションを選択した場合、gridview の追加/編集ボタンをクリックすると、1 つのフォーム ページに gridview のすべてのフィールドが表示されます。フォームでは、ユーザーは gridview のレコードを追加/編集できます。

誰でもこれについてアイデアを出すことができますか?

ここに DataGrid のメイン コードがあります。

<Controls:DataGrid Grid.Row="0" SelectedItem="{Binding Path=CurrentSelectedItem, Mode=TwoWay}" AutoGenerateColumns="False" SelectionMode="Single">
              <Controls:DataGrid.Columns>
                <Controls:DataGridTemplateColumn>
                  <Controls:DataGridTemplateColumn.CellTemplate>
                    <DataTemplate>
                      <Button Content="Remove" VerticalAlignment="Center" HorizontalAlignment="Center" Command="{Binding Source={StaticResource cmdDeleteRecord}}" CommandParameter="{Binding Path=Attribute[ExtensionDataId].Value}" Margin="8,0,8,0" />
                    </DataTemplate>
                  </Controls:DataGridTemplateColumn.CellTemplate>
                </Controls:DataGridTemplateColumn>
                <Controls:DataGridTemplateColumn HeaderStyle="{StaticResource WrappedColumnHeaderStyle}" Header="Vendor" CanUserSort="True" ToolTipService.ToolTip="Vendor" SortMemberPath="VendorPrincipalId_Name-Reference" MaxWidth="250">
                  <Controls:DataGridTemplateColumn.ClipboardContentBinding>
                    <Binding Path="Attribute[VendorPrincipalId_Name].Value" Mode="TwoWay" />
                  </Controls:DataGridTemplateColumn.ClipboardContentBinding>                  
                  <Controls:DataGridTemplateColumn.CellTemplate>
                    <DataTemplate>
                      <StackPanel>
                        <TextBox Style="{DynamicResource GridCellTemplateTextBox}" TextWrapping="Wrap">
                          <TextBox.Text>
                            <Binding Path="Attribute[VendorPrincipalId_Name].Value" Mode="TwoWay" />
                          </TextBox.Text>
                        </TextBox>
                      </StackPanel>
                    </DataTemplate>
                  </Controls:DataGridTemplateColumn.CellTemplate>
                </Controls:DataGridTemplateColumn>
                <Controls:DataGridTemplateColumn HeaderStyle="{StaticResource WrappedColumnHeaderStyle}" Header="Vendor's Key" CanUserSort="True" ToolTipService.ToolTip="Vendor's Key" SortMemberPath="Attribute[VendorKey].Value" MaxWidth="250">
                  <Controls:DataGridTemplateColumn.ClipboardContentBinding>
                    <Binding Path="Attribute[VendorKey].Value" />
                 </Controls:DataGridTemplateColumn.ClipboardContentBinding>                
                  <Controls:DataGridTemplateColumn.CellTemplate>
                    <DataTemplate>
                      <StackPanel>
                        <TextBox Style="{DynamicResource GridCellTemplateTextBox}" TextWrapping="Wrap">
                          <TextBox.Text>
                            <Binding Path="Attribute[VendorKey].Value" />
                          </TextBox.Text>
                        </TextBox>
                      </StackPanel>
                    </DataTemplate>
                  </Controls:DataGridTemplateColumn.CellTemplate>
                </Controls:DataGridTemplateColumn>
              </Controls:DataGrid.Columns>
            </controls:DataGrid>
4

1 に答える 1

0

次のように、ユーザーがグリッド内の行を編集できるようにするトリガーを使用して問題を解決しました。

<Controls:DataGridTemplateColumn Header="Note Title" CanUserSort="True" ToolTipService.ToolTip="Note Title"  MaxWidth="250">                                  <Controls:DataGridTemplateColumn.CellStyle>
                                    <Style TargetType="Controls:DataGridCell">
                                        <Style.Triggers>
                                            <Trigger Property="IsSelected" Value="true">
                                                <Setter Property="Template">
                                                    <Setter.Value>
                                                        <ControlTemplate>
                                                            <TextBox TextWrapping="Wrap">
                                                                <TextBox.Text>
                                                                    <Binding Path="ColumnValue" Mode="TwoWay" />
                                                                </TextBox.Text>
                                                            </TextBox>
                                                        </ControlTemplate>
                                                    </Setter.Value>
                                                </Setter>
                                            </Trigger>
                                            <Trigger Property="IsSelected" Value="false">
                                                <Setter Property="Template">
                                                    <Setter.Value>
                                                        <ControlTemplate>
                                                            <TextBlock TextWrapping="Wrap">
                                                                <TextBlock.Text>
                                                                    <Binding Path="ColumnValue" Mode="TwoWay" />
                                                                </TextBlock.Text>
                                                            </TextBlock>
                                                        </ControlTemplate>
                                                    </Setter.Value>
                                                </Setter>
                                            </Trigger>
                                        </Style.Triggers>
                                    </Style>
                                </Controls:DataGridTemplateColumn.CellStyle>
                            </Controls:DataGridTemplateColumn>

使用できるCellEditingTemplateもありますが、うまく機能しませんでした。そこでトリガーを使いました。ユーザーが行を選択すると、TextBlock の代わりに列のテンプレートに TextBox を設定します。

于 2012-11-28T08:45:58.560 に答える