MAUI中实现可折叠列表项最直接方式是使用Expander控件配合CollectionView,通过为每个数据项添加IsExpanded属性并绑定,实现独立展开/收起;需确保模型实现INotifyPropertyChanged,XAML正确绑定,注意iOS早期版本布局问题。

MAUI 中实现可折叠的列表项,最直接的方式是使用内置的 Expander 控件,配合 CollectionView 或 ListView 使用。它本身不支持直接放在 ItemTemplate 里“自动展开/收起”,但通过绑定 + 数据模型控制,完全可以做到每个列表项独立折叠。
Expander 是一个容器控件,包含 Header(点击区域)和 Content(折叠内容)。默认点击 header 切换展开状态:
<Expander>
<Expander.Header>
<Label Text="点击展开详情" />
</Expander.Header>
<Expander.Content>
<StackLayout Padding="10">
<Label Text="这里是隐藏的详细信息..." />
<Button Text="操作按钮" />
</StackLayout>
</Expander.Content>
</Expander>
关键点:每个数据项需自带一个 IsExpanded 属性,并绑定到 Expander 的 IsExpanded 属性。这样每条数据控制自己的展开状态,互不影响。
ListItem):
public class ListItem : INotifyPropertyChanged
{
private bool _isExpanded;
public string Title { get; set; }
public string Detail { get; set; }
public bool IsExpanded
{
get => _isExpanded;
set
{
if (_isExpanded != value)
{
_isExpanded = value;
OnPropertyChanged();
}
}
}
public event PropertyChangedEventHandler PropertyChanged;
protected virtual void OnPropertyChanged([CallerMemberName] string propertyName = null) =>
PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(propertyName));
}
CollectionView.ItemTemplate 中使用 Expander:
<CollectionView ItemsSource="{Binding Items}">
<CollectionView.ItemTemplate>
<DataTemplate x:DataType="model:ListItem">
<Expander IsExpanded="{Binding IsExpanded}">
<Expander.Header>
<Label Text="{Binding Title}" FontSize="16" Margin="10,5" />
</Expander.Header>
<Expander.Content>
<StackLayout Padding="10,0,10,10">
<Label Text="{Binding Detail}" />
<Button Text="编辑" Command="{Binding Source={RelativeSource AncestorType={x:Type vm:MainPageViewModel}}, Path=EditCommand}" CommandParameter="{Binding}" />
</StackLayout>
</Expander.Content>
</Expander>
</DataTemplate>
</CollectionView.ItemTemplate>
</CollectionView>
ListItem.IsExpanded = false
StackLayout 或 Grid 设为 header,或用 TapGestureRecognizer 手动切换 IsExpanded
Expander.AnimatedExpandCollapse(部分平台支持),或用 VisualStateManager 配合 ScaleTo/FadeTo
HeightRequest + 动画控制Expander 在 Android 和 Windows 上表现稳定;iOS 上早期版本(.NET MAUI 6.0~7.0)有轻微布局重绘问题,升级到 .NET MAUI 8.0+ 已基本修复。若遇到内容不显示,检查是否遗漏 x:DataType 或绑定路径错误,以及 INotifyPropertyChanged 是否正确触发。
基本上就这些 —— Expander 不复杂但容易忽略绑定细节,只要模型可通知、XAML 绑定写对,每个列表项就能独立、流畅地折叠展开。
以上就是MAUI怎么实现一个可折叠的列表项 MAUI Expander控件的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号