0

0

MAUI SwipeView怎么用 MAUI侧滑菜单项教程

星降

星降

发布时间:2025-12-18 12:48:08

|

861人浏览过

|

来源于php中文网

原创

MAUI 的 SwipeView 是原生支持 iOS、Android 和 Windows 触控的侧滑菜单控件,需注意平台行为差异(如 Windows 不支持鼠标拖拽)、Drag/Reveal 动画模式设置、SwipeItems 方向限制及 SwipeStarted/Changing/Ended 事件监听。

maui swipeview怎么用 maui侧滑菜单项教程

MAUI 的 SwipeView 是实现侧滑菜单(比如左滑删、右滑标记)最直接的控件,它不依赖第三方库,原生支持 iOS、Android 和 Windows(触控模式),用法清晰但有几个关键点容易踩坑。

基础结构:内容 + 轻扫项

SwipeView 本质是一个“包装器”——它包裹一个主内容(如 Label、StackLayout),再通过 LeftItems/RightItems/TopItems/BottomItems 添加可触发的菜单项。Content 属性是隐式内容属性,不用写 Content= 标签。

  • 只允许一个直接子元素作为 Content(如不能直接放多个 Label,需用 StackLayout 包一层)
  • 每个方向最多一组 SwipeItems,每组可含多个 SwipeItem(例如右滑弹出“标记”和“归档”两个按钮)
  • SwipeItem 支持 Text、IconImageSource、BackgroundColor、Command/CommandParameter,还能响应 Invoked 事件

平台行为差异必须注意

SwipeView 在不同系统上默认交互逻辑不同,尤其 Windows 只响应触控,鼠标拖拽无效;iOS 和 Android 还提供两种展开动画模式:

  • Reveal(默认):轻扫时内容不动,菜单项像“帘子”一样从边缘渐显
  • Drag:轻扫时整个内容区域被拖动,菜单项随动滑入(更接近原生 iOS 邮件体验)
  • XAML 中启用 Drag 模式需加平台特定命名空间,例如 iOS:ios:SwipeView.SwipeTransitionMode="Drag"
  • C# 中调用:swipeView.On().SetSwipeTransitionMode(SwipeTransitionMode.Drag)

常用交互控制技巧

除了用户手动滑动,你还可以用代码控制开关状态或监听过程:

Asksia
Asksia

Asksia AI - 最好的AI老师,可靠的作业助手

下载
  • 调用 swipeView.Open(OpenSwipeItem.Left).Close() 主动展开/收起
  • 监听 SwipeStartedSwipeChangingSwipeEnded 三个事件,其中 SwipeEndedEventArgs 提供 IsOpen(是否最终打开了)和 SwipeDirection
  • 设置 Threshold 属性(double 类型)可调整触发完全展开所需的滑动距离,默认约 0.5,值越小越灵敏
  • 若想禁止某个方向滑动,直接不定义对应 Items(比如没设 RightItems,就无法右滑)

实际小例子:左滑删除条目

在 ListView 或 CollectionView 的 DataTemplate 中嵌入 SwipeView,是最典型场景:


  
    
      
    
  
  

后台 C# 中处理删除逻辑即可,注意 Invoked 事件里可通过 sender 或绑定上下文获取当前数据项。

基本上就这些。用好 SwipeView 不复杂,但得记清平台限制、动画模式选择和事件触发时机——特别是别在 Windows 上指望鼠标拖拽生效。

相关专题

更多
c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

53

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

100

2025.10.23

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

667

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1125

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

799

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

453

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2350

2023.08.08

windows自动更新
windows自动更新

Windows操作系统的自动更新功能可以确保系统及时获取最新的补丁和安全更新,以提高系统的稳定性和安全性。然而,有时候我们可能希望暂时或永久地关闭Windows的自动更新功能。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

823

2023.08.10

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

7

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Excel 教程
Excel 教程

共162课时 | 13万人学习

Java 教程
Java 教程

共578课时 | 49.8万人学习

Uniapp从零开始实现新闻资讯应用
Uniapp从零开始实现新闻资讯应用

共64课时 | 6.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号