10

RowStyle後に適用されるようにするにはどうすればよいAlternatingRowBackgroundですか? 現在はそうではありませんが、交互の行の背景に関係なく背景IsOrangetrue持つアイテムが必要です。Orange

XAML:

<DataGrid Name="g"
    AlternatingRowBackground="Blue" 
    AlternationCount="2" 
    ...
    SelectionMode="Single">
    <DataGrid.RowStyle>
        <Style TargetType="DataGridRow">
            <Style.Triggers>
                <DataTrigger Binding="{Binding IsOrange}" Value="Y">
                    <Setter Property="Background" Value="Orange" />
                </DataTrigger>
            </Style.Triggers>
        </Style>
    </DataGrid.RowStyle>
    ...
</DataGrid>
4

2 に答える 2

19

バグではありません。ではStyle、交互の行に設定されたローカル値を上書きすることはできません。これがうまくいかない理由です

<DataGrid AlternatingRowBackground="Blue"

しかし、設定AlternatingRowBackgroundすれStyle

<DataGrid.Style>
    <Style TargetType="DataGrid">
        <Setter Property="AlternatingRowBackground" Value="Blue"/>
    </Style>
</DataGrid.Style>

この回答に感謝します。

于 2012-12-17T14:43:21.113 に答える
2

私のプログラムでは、1 つの DataGird のみを含むメイン ウィンドウに加えて、2 つのクラスがあります。ファーストクラスから始めましょう:

MyClass.cs:

public class MyClass
{
    public bool IsOrange { get; set; }

    public string Name { get; set; }
}

IsOrange行をオレンジにするかどうかを指定する 2 つのプロパティしかありません。((他のプロパティは気にしないでください。))

現在、ビュー モデル クラスには MyClass のコレクションのみが含まれています。

MyClassViewModel.cs:

public class MyClassViewModel
{
    public ObservableCollection<MyClass> con { get; set; }

    public MyClassViewModel()
    {
        con = new ObservableCollection<MyClass>();

        con.Add(new MyClass { IsOrange = true, Name = "Aa" });
        con.Add(new MyClass { IsOrange = true, Name = "Bb" });
        con.Add(new MyClass { IsOrange = false, Name = "Cc" });
        con.Add(new MyClass { IsOrange = false, Name = "Dd" });
        con.Add(new MyClass { IsOrange = false, Name = "Ee" });
        con.Add(new MyClass { IsOrange = true, Name = "Ff" });
        con.Add(new MyClass { IsOrange = true, Name = "Gg" });
        con.Add(new MyClass { IsOrange = false, Name = "Hh" });
    }
}

MainWindow.xaml で:

<Grid>
    <DataGrid Margin="10" ItemsSource="{Binding Path=con}" >
        <DataGrid.RowStyle>
            <Style TargetType="DataGridRow">
                <Style.Triggers>
                    <DataTrigger Binding="{Binding Path=IsOrange}" Value="true">
                        <Setter Property="Background" Value="Orange" />
                    </DataTrigger>
                </Style.Triggers>
            </Style>
        </DataGrid.RowStyle>
    </DataGrid>
</Grid>

最後に MainWindow.xaml.cs で:

public partial class MainWindow : Window
{
    MyClassViewModel VM = new MyClassViewModel();

    public MainWindow()
    {
        InitializeComponent();

        DataContext = VM;
    }
}

これが結果です。

ここに画像の説明を入力

メールを送信して、アプリを送信できます。

幸運を :)

于 2012-12-17T15:28:03.390 に答える