大家好,我正在努力解决这个问题。我有一个名为“ROOT”的列表,我将其应用于该列表的 ItemTemplate“RootTemplate”。在“RootTemplate”中,我有另一个列表“BRANCH”和另一个模板“BranchTemplate”,我想要实现的是在 BRANCH 列表中预先选择其中的一些 listViewItems。
<ResourceDictionary
<DataTemplate x:Key="RootTemplate" >
<ListViewItem>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" MinWidth="0"/>
<ColumnDefinition Width="Auto" MinWidth="0"/>
</Grid.ColumnDefinitions>
<ListView ItemsSource="{Binding Branches}" ItemTemplate="{StaticResource BranchTemplate}" SelectionMode="Multiple"/>
</Grid>
</ListViewItem>
</DataTemplate>
<DataTemplate x:Key="BranchTemplate">
<ListViewItem IsSelected="{Binding IsChecked, Mode=TwoWay}">
<Grid>
<Grid.RowDefinitions>
<RowDefinition Width="Auto"/>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto"/>
</Grid.ColumnDefinitions>
<TextBlock Text="{Binding Name}"/>
</Grid>
</ListViewItem>
</DataTemplate>
我的 ViewModel 很简单
public class Root: ReactiveObject
{
public ObservableCollectionExtended<Branch> Branches{ get; } = new ObservableCollectionExtended<Branch>();}
public class Branch: ReactiveObject
{
private bool _isChecked = true;
public bool IsChecked
{
get => _isChecked;
set
{
this.RaiseAndSetIfChanged(ref _isChecked, value);
}
}
private string _name;
public string Name
{
get => _name;
set
{
this.RaiseAndSetIfChanged(ref _name, value);
}
}}
在 BranchTemplate 中,我使用 IsSelected 绑定到 IsChecked 属性。它工作正常,当我单击列表时 IsChecked 会相应更改,当我(在运行时)更改 IsChecked 属性时,我可以看到更改反映在 UI 上。但我无法将 IsChecked 初始化为 true(如您所见代码)。即使我这样做了,当我运行应用程序 IsChecked 时,它也会自动设置回 false,并且在 UI 中未选择 listItems。