1

親愛なる、DataGrid が NewClient オブジェクトのコレクションである Collection ClientMarketCode にバインドされている間、ViewModel の監視可能なコレクション Markets にバインドされたデータグリッドにコンボボックス列があります。ClientMarketCode には、Code、MarketCodeTypeID、MarketID というプロパティがあります。したがって、ユーザーがマーケットを編集したい場合に備えて、マーケットにバインドされたコンボボックスを使用しました。これには、すべてのマーケットが表示され、ユーザーが希望するマーケットを選択します。選択した行のマーケットの値が選択後に変更されないため、他のマーケットを選択する際に問題がありますコンボボックスからの新しい市場。

例えば:

最初の行にKSA市場があるとしましょう.USAをクリックした後、コンボボックスからUSAに変更すると、bacoがKSAに戻ります.

ここに私のビューモデルがあります:

public class MarketsViewModel : ObservableObject, IMarketsViewModel, INavigationAware, IConfirmNavigationRequest, IRegionMemberLifetime
{
    #region MarketsViewModel
    public MarketsViewModel()
    {
        this.GetMarkets();
    }
    public ObservableCollection<Market> Markets
    {
        get { return m_Market; }
        set
        {
            m_Market = value;
            RaisePropertyChanged("Markets");
        }
    }

    private void GetMarkets()
    {
        try
        {
            Market[] MarketArr;

            using (var client = new ClientServiceProxy())
            {
                MarketArr = client.GetAllMarkets();
            }
            if (MarketArr != null)
            {
                this.Markets = new ObservableCollection<Market>(MarketArr);
            }
        }
        catch (Exception e)
        {
            MessageBox.Show(e.Message);
        }
    }
}

XAML は次のとおりです。

<Custom:C1DataGrid x:Name="c1DataGrid"  
                   AutoGenerateColumns="False"

                   Height="490"  ItemsSource="{Binding    Path=NewClient.ClientMarketCodes,Mode=TwoWay,UpdateSourceTrigger=LostFocus,ValidatesOnDataErrors=True,ValidatesOnExceptions=True}">
        <LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">
            <GradientStop Color="#FFBEBE00" Offset="0.5"/>
            <GradientStop Color="#FFEDED9A" Offset="0.496"/>
        </LinearGradientBrush>
    </Custom:C1DataGrid.HeaderBackground>
    <Custom:C1DataGrid.Columns>
        <!--<Custom:DataGridCheckBoxColumn  Header="Code"/>-->

        <Custom:DataGridTemplateColumn Header="Markets">
            <Custom:DataGridTemplateColumn.CellTemplate>
                <DataTemplate>
                    <TextBlock Text="{Binding MarketCodeType.Market.NameA}"/>
                </DataTemplate>
            </Custom:DataGridTemplateColumn.CellTemplate>
            <Custom:DataGridTemplateColumn.CellEditingTemplate>
                <DataTemplate>
                    <ComboBox Name="cmbMarkets" ItemsSource= "{Binding RelativeSource={RelativeSource FindAncestor,AncestorType=my:MarketsView},Path=DataContext.Markets,Mode=TwoWay}" 
DisplayMemberPath="NameA" SelectedValue="{Binding Path=MarketCodeType.Market.MarketID,Mode=TwoWay}" 
        SelectedValuePath="MarketCodeType.MarketID"
SelectedItem="{Binding RelativeSource={RelativeSource FindAncestor,AncestorType=my:MarketsView},Path=DataContext.selectedMarket,Mode=TwoWay}"    />
                </DataTemplate>
            </Custom:DataGridTemplateColumn.CellEditingTemplate>
        </Custom:DataGridTemplateColumn> 


        </Custom:DataGridTemplateColumn>
    </Custom:C1DataGrid.Columns>

</Custom:C1DataGrid>
4

1 に答える 1

2

私のコメントを要約すると、バインディングは次のいずれかになります。

<DataTemplate>
    <ComboBox Name="cmbMarkets" DisplayMemberPath="NameA"
              ItemsSource= "{Binding RelativeSource={RelativeSource FindAncestor,AncestorType=my:MarketsView},Path=DataContext.Markets}"
              SelectedItem="{Binding MarketCodeType.Market, Mode=TwoWay}"/>
</DataTemplate>

または(それについてはよくわかりません):

<DataTemplate>
    <ComboBox Name="cmbMarkets" DisplayMemberPath="NameA"
              ItemsSource= "{Binding RelativeSource={RelativeSource FindAncestor,AncestorType=my:MarketsView},Path=DataContext.Markets}"
              SelectedValue="{Binding MarketCodeType.Market.MarketID, Mode=TwoWay}"
              SelectedValuePath="MarketID"/>
</DataTemplate>
于 2013-09-14T18:58:04.180 に答える