Rik*_*ere 2 c# wpf xaml listbox mvvm
我是 MVVM/WPF 的新手,经过几个小时的研究,没有为我的项目找到任何真正有用/有效的答案,我决定试一试并尝试在这里提问。
我想从我的列表框中选择一个项目,它使用一个列表作为一个项目源。
相关视图模型:
public class FavoriteStructureVm : INotifyPropertyChanged
{
#region
public event PropertyChangedEventHandler PropertyChanged;
private void OnPropertyChanged(string propertyName)
{
if (this.PropertyChanged != null)
PropertyChanged(this, new PropertyChangedEventArgs(propertyName));
}
#endregion
public ObservableCollection<FavoriteDataVm> Favorites { get; set; }
public int SelectedIndex { get; set; }
private FavoriteDataVm _selectedItem;
public FavoriteDataVm SelectedItem
{
set
{
_selectedItem = value;
var item = (FavoriteDataVm)_selectedItem;
if (item.Type == FavoriteDataType.Add)
{
SelectedIndex = 1;
}
}
}
}
Run Code Online (Sandbox Code Playgroud)
ListBox 默认包含几个项目,最后一个始终是 type 之一Add,如果选择它,可能会添加一个新项目并默认选择它,或者如果没有添加新项目,则选择先前选择的项目。对于简单性,无论是否添加新项目,所选项目都将为 1。
无论身在何处,什么我试图更新OnPropertyChanged它并没有在视图中,通过添加/插入一个新的更新SelectedIndex的,但是FavoriteDataVm到ObservableCollection<FavoriteDataVm> Favorites时,SelectedIndex在视图中得到更新。将新项目添加到列表的过程并不总是发生,但我想总是更新SelectedIndex.
相关 XAML:
<ListBox Name="favMenu" ItemsSource="{Binding Favorites}" SelectionMode="Single"
HorizontalAlignment="Center" VerticalAlignment="Top"
BorderThickness="0" Background="Transparent" Height="{Binding ElementName=window, Path=ActualHeight}"
SelectedItem="{Binding SelectedItem, Mode=TwoWay}"
SelectedIndex="{Binding SelectedIndex, Mode=TwoWay}"
>
<ListBox.Resources>
<Style TargetType="ListBoxItem">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="ListBoxItem">
<Border Background="Transparent" SnapsToDevicePixels="true">
<ContentPresenter />
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</ListBox.Resources>
<!--changing default orientation-->
<ListBox.ItemsPanel>
<ItemsPanelTemplate>
<VirtualizingStackPanel Orientation="Vertical"/>
</ItemsPanelTemplate>
</ListBox.ItemsPanel>
<ListBox.ItemTemplate>
<DataTemplate>
<Border x:Name="Border"
BorderThickness="0" BorderBrush="Black" Background="{x:Null}"
Width="60" Height="60" CornerRadius="30" Margin="{Binding Margin}"
ToolTip="{Binding Name}">
<Image Source="{Binding ImageUri}" Width="60" Height="60" Stretch="UniformToFill">
<Image.Clip>
<EllipseGeometry RadiusX="30" RadiusY="30" Center="30,30"/>
</Image.Clip>
</Image>
</Border>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
Run Code Online (Sandbox Code Playgroud)
我找到了一种解决方法来创建一个虚拟项目并将其删除,因为添加某些内容似乎会更新SelectedIndex视图中的内容。我不认为它是一个解决方案,因为它有很多缺点。
所以这实际上提出了两个问题:
SelectedIndexListBox 的?还有一个初学者问题,因为我是 MVVM 的新手:
如何更新 ListBox 的 SelectedIndex?
您可以通过获取SelectedItem源集合中的索引来获取所选索引:
int selectedIndex = (SelectedItem != null && Favorites != null) ? Favorites.IndexOf(SelectedItem) : -1;
Run Code Online (Sandbox Code Playgroud)
您可以通过设置SelectedItem属性来选择一个项目:
SelectedItem = Favorites[1]; //selects the second item
Run Code Online (Sandbox Code Playgroud)
您不应同时绑定SelectedItem和 的SelectedIndex属性ListBox。这些必须同步。SelectedIndex="{Binding SelectedIndex, Mode=TwoWay}"从 XAML 中删除。
另请注意,如果您打算动态更新源属性,则需要PropertyChanged为该属性提高视图以刷新:
private int _selectedIndex;
public int SelectedIndex
{
get { return _selectedIndex; }
set { _selectedIndex = value; OnPropertyChanged("SelectedIndex"); }
}
private FavoriteDataVm _selectedItem;
public FavoriteDataVm SelectedItem
{
set
{
_selectedItem = value;
OnPropertyChanged("SelectedItem");
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3601 次 |
| 最近记录: |