移动端交互控件规范总结:弹窗(二)

作者:ZYUN(20191018)
预计阅读时长:35 分钟(9765 字;60 图)
温馨提示:文中部分配图可能有点模糊,如有需要可点击「移动端交互控件规范总结:弹窗」查看大图(第一次加载可能会有点慢~)。

以下内容主要以 iOS 官方设计指南和网络上的相关文章为参考,但同时也包含个人理解与思考,并非绝对、唯一的标准。如有错漏,欢迎指正呀~如有其他任何建议,也欢迎一起讨论呀~超级无敌宇宙飞船航空母舰感谢~

温馨提示~文章实在是太长了,但内容算是设计指南类的,不从头看到尾也是可以的~通过下面的目录可找到感兴趣的、想了解的部分~提前感谢耐心阅读~



1. Toasts 轻提示

1.1. 简介

Toasts 原本是 Android 系统独有的控件,但我在最新的 Material Design 里已经找不到这个控件了( Android 的开发者指南中有这个控件)。
根据网上相关文章的介绍,在 Android 之前的官方设计规范里,Toasts 应该是非模态的、纯文本的、出现在屏幕底部,且不支持交互的。但随着这个概念的泛化,现在已经出现了各种打破规范的 Toasts ,比如模态的、带图标的、可交互的等等。

而 iOS 系统,一直以来都没有 Toasts 这个概念,类似于 Toasts 的组件是 UIProgressHUD,例如,调节音量时的提示(这个控件在 iOS 13 之后也有了更新)。但这个组件是系统私有的,第三方应用无法直接获取使用。所以,我们在 iOS 第三方应用中看到的很多 HUD 都是第三方控件(如 MBProgressHUD )或者是应用自定义的。

在这里,我们把所有响应用户操作而呈现,短暂显示后可自动消失的轻量级提示都统一称为 Toasts


1.2. 特点及使用场景

(1) 对用户干扰较小,是一种轻量级的反馈提示。不适用于展示大量文案、重要信息。
(2) 主要用于通知用户操作结果或状态变化(重点在告知用户信息,而不是提供操作)。
(3) 主要类型包括:
① 普通提示(成功提示、失败提示、警告提示):非模态,不打断用户当前的操作任务;不支持手动关闭,不支持交互,显示几秒后自动消失。



② 加载提示:有两种加载场景。

  • 不需要打断用户的操作:非模态,不支持手动关闭,不支持交互,加载完成后自动消失。
    常用于进入新页面时加载数据的提示。
    这种加载提示一般可用其他体验更好的方式替代,例如,使用局部加载而不是全局加载、将加载提示放到导航栏、将加载提示放到触发按钮上等(见文末的「10. 模态情境的使用」部分)。
  • 需要打断用户的操作:模态,一般带有「取消」按钮;加载完成自动消失;点击「取消」按钮,可取消加载,关闭提示。
    如果用户只能等加载结束后才能进行其他操作,但中断时间比较短,就可以使用这种模态的加载提示,例如支付、下载、上传等。(如果中断时间比较长,一般会使用新页面展示加载进程。)
    参考 《5000 字,总结 App 加载设计》 ,这类场景一般有两种情况:一是用户如果执行其他操作将会打断正在进行的加载过程;二是用户当前执行的操作本身不能和其他操作同时进行。这个需要根据具体的功能、业务和开发实现技术等因素综合确定。


1.3. 设计原则

(1) 一次只显示一个 Toast。
(2) 视觉样式
可包含简单图标,也可为纯文本。
(3) 文案
① 尽量精简。参考 Ant Design ,包含图标的 Toasts 一般为 4-6 个字,纯文本的 Toasts 一般不超过 14 个字。
② 尽可能使用与触发提示的操作直接相关的动词或词组,如,评论中、刷新成功等;若是失败提示,直接指出出错原因。
③ 尽量避免使用 “你”、“你的”、“我”、“我的” 这类代词。
(4) 显示时长
Android 的开发文档 中提到的两个默认时长分别为 2s 和 3.5s。但是暂时没有查到它的设计缘由,不知道是不是仅适用于英文环境。
根据网上相关的文章,中文环境下,成人的平均阅读速度为一分钟 300-500 字,按一秒钟 7 个字计算的话,6 个字以内显示 1s,7-10 个字显示 1.5s,11-14 个字,显示 2s。
此外,参考 《人机工程学在交互设计中的运用》 ,对于加载提示:如果 1s 内加载完成,不显示加载提示;1~6s 加载完成的,显示加载提示;6s 内未加载出来的,显示加载失败。
(5) 显示位置
① 同类型 Toasts 的出现位置最好保持一致,用户会习惯于在固定的位置感知反馈信息。
② 一般在屏幕中居中。但,对于普通提示,显示在顶部更好,可减少对用户的打扰,并且不会因为键盘的出现而浮动或被挡住。



2. Snackbars 底部提示框

2.1. 简介

Snackbars 是 Android 平台的控件,跟 Toasts 非常相似。两者的区别在于,Snackbars 可以包含一个操作(不是「取消」这类用于关闭的按钮)。(根据网上的相关文章,在以前的规范里,Snackbars 是支持主动滑动关闭的。但是,现在 Material Design 的指南里并没有这一项。)
虽然现在的 Material Design 里已经找不到 Toasts,Snackbars 也可以取代 Toasts,但在实际运用中,还是 Toasts 用得比较多,用户可能还是对 Toasts 比较熟悉。


2.2. 官方规范

(1) 非模态。
(2) 显示在屏幕底部。
(3) 一次只展示一个 Snackbar。
(4) 只能包含一个文本按钮,且文本颜色不能与提示信息文本颜色一样。
(5) 文本按钮不能是「取消」、「忽略」等用于关闭 Snackbars 的按钮。
(6) 背景必须完全不透明,并带阴影。
(7) 显示 4~10s 后自动消失,不支持手动关闭


2.3. 实际应用

实际运用中,有一个样式与 Snackbars 非常类似的比较常见的控件(如下图所示),网络上一些文章将这种底部提示框也称为 Snackbars。但它跟官方定义的 Snackbars 的交互方式已经不太一样了,这种底部提示框:
(1) 非模态。
(2) 显示在屏幕底部。
(3) 大部分情况下只包含一个按钮,但有时也包含「关闭」按钮。按钮的形式可以是图标、文本按钮或填充按钮。
(4) 背景一般为半透明黑色背景。
(5) 一般不会自动消失,可手动关闭或执行相应操作后消失



3. Pickers 选择器

3.1. 简介

选择器展示了一组值,用户可以从中进行选择,一般是选择一个选项。通常用于表单


3.2. 类型

3.2.1. Wheel Pickers 滑轮选择器

(1) 类型

① Native Wheel Pickers 原生滑轮选择器

  • iOS 系统原生的滑轮选择器,目前比较少见。
  • 显示在内容视图中,通常是嵌入表单中或出现在屏幕底部
  • 通常包括一个或多个滑轮,每个滑轮包含一组值。
  • 当前选中的值在中间,以深色标识。
  • 选中选项后,再次点击触发控件或界面中其他位置,关闭选择器,选择成功。



② Custom Wheel Pickers 自定义滑轮选择器
包含「取消」和「确定」按钮,选中选项后,点击「确定」按钮,选择成功,同时关闭选择器。点击遮罩层可关闭选择器,效果同点击「取消」按钮。


(2) 使用场景

当用户对整组值都比较熟悉(如常见的年月日、省份城市等)的时候,才使用滑轮选择器。因为当滑轮静止的时候,大部分的值会被隐藏,所以最好是在用户对所有值均有预期的情况下才使用滑轮选择器。
② 若备选项数量非常多,一般不推荐使用滑轮选择器。因为滑轮选择器的高度较小,滚动起来需要花费较长的时间。
③ 若滑轮个数较多,一般也不推荐使用滑轮。因为滑轮是横向排列的,横向屏幕空间不够时,可能无法完整显示数据,导致理解、识别困难。参考 Ant Design,最多展示 5 个滚轮,具体视情况而定。
④ 若需要展示一大组用户并不熟悉的选项,可使用下文的「5.2.2 Bottom Menus 底部菜单」。

5.2.2. Custom Pickers 自定义选择器

使用底部模态面板来承载选择器的内容,如下图的地址选择器。



4. Popovers 气泡浮层

4.1. 简介

气泡浮层是⽤户点击某个控件或者屏幕上某个区域后,出现在屏幕其他内容之上的临时窗⼝。通常包含一个指向触发它显示的控件或区域的箭头,具有明确的指向性。


4.2. 类型

4.2.1. Native Popovers 原生气泡浮层

(1) 系统原生的气泡浮层可以包含各种各样的元素,如导航栏、 ⼯具栏、标签栏、表格、精选窗口、 图像、地图和自定义窗⼝等。
(2) 包含「取消」按钮,点击「取消」按钮可关闭浮层。
(3) 既有模态的,也有非模态的
模态的气泡浮层:打开气泡浮层后,其他操作将被中断。可通过浮层上的「取消」或其他按钮关闭浮层。
非模态的气泡浮层:可通过点击浮层上的按钮或屏幕中其他区域来关闭浮层。
(4) 仅在较大的屏幕上使用,如,iPad。(如果需要在手机上用浮层来承载同样的内容,可以使用下文的「8. Full-screen Modal Views 全屏模态视图」。)


4.2.2. Tooltip 文字提示

在手机端,有两种常见的小型气泡浮层。其中一种就是 Tooltips。
(1) 用于简单的信息提示或操作引导,进入特定页面、点击特定元素或满足特定条件后触发显示。
(2) 通常是非模态的。
(3) 短暂显示自动消失,或点击界面中其他区域、点击该元素、执行其他指定操作后关闭浮层。有时候也会包含一个关闭按钮,点击后可关闭浮层。


4.2.3. Pop Menus 气泡菜单

手机端另外一种常见的小型气泡浮层是 Pop Menus。详情见下文的「5.3.2. Pop Menus 气泡菜单」。

5. Menus 菜单

5.1. 简介

将动作或内容选项折叠收起来,通过点击、长按等手势唤起临时视图,进行菜单选择。通常是折叠次要场景的、较低频的选项。
所以,菜单常用的使用场景有:
(1) 启动任务:将操作命令收纳起来,点击选项后在当前页面执行某个操作,或导航至目标页面。(菜单项不需要选中状态。)
(2) 筛选内容:将筛选条件收纳起来,选择选项后对当前页面内容进行筛选。(菜单项有选中状态。)
单一筛选条件且单选:常采用列表的形式。
多个筛选条件或多选:常采用标签的形式。
复杂的筛选条件:一般会采用顶部 tab、侧边 tab 与列表或标签结合的形式。

5.2. iOS 两种常用的特定菜单

5.2.1. Action Sheets 动作面板

(1) 简介
Action Sheets 为了响应某个控件或操作而出现,提供与当前情境相关的两个或多个选项。使用 Action Sheets 来让用户启动某项任务,或在用户执行具有潜在破坏性的操作之前向用户请求确认。
在小屏上,Action Sheets 从屏幕底部向上滑出。在大屏上,Action Sheets 以 Popovers(气泡浮层)的形式呈现。



(2) 特点及使用场景
① 由用户某个操作行为触发。
② 提供一系列在当前情境下可以完成当前任务的操作。
③ 在用户完成一项可能有风险的操作前获得用户的确认。

(3) 设计原则
① 模态。
② 从屏幕底部向上滑出。
③ 包含两个或两个以上的按钮,点击按钮即执行相应命令。
④ 提供「取消」按钮,点击「取消」按钮或遮罩层关闭 Action Sheets。
⑤ 最好使用红色文字来表示可能存在破坏性的操作。
⑥ 避免操作太多,需要进行滚动的情况。
⑦ 可在顶部对执行对象进行描述,包括图片、文本等形式。


5.2.2. Activity Views 活动视图

(1) 简介
Activity Views 用于显示用户可针对当前内容执行的一系列服务(活动)。通常情况下,点击之后该项活动会立刻执行。若某项活动过于复杂,系统则会进一步请求获取更多的信息后才为用户执行该服务。



(2) 设计原则
① 模态。
② 点击「取消」按钮或者遮罩层关闭 Activity Views。
③ 确保活动是可以对当前窗口中的内容进⾏操作的。
④ 活动标题尽量精简,且,标题中尽量避免包含公司或产品名称。


5.3. 常见自定义菜单

5.3.1. Pop Menus 气泡菜单

(1) 以 “小型气泡浮层” 的形式承载菜单功能。
(2) 通常包含一个箭头,指向浮层出现的位置(有时候也不包含箭头)。
(3) 选中某个菜单项后,自动关闭气泡浮层。
(4) 一般是模态的。可在气泡浮层下显示遮罩层,也可不显示。点击遮罩层或界面中其他区域,可关闭浮层。(比较特别的是,像微信和 QQ,弹出气泡浮层后,界面中其他元素均不可点击,但仍可切换底部 tab。)
(5) 与 Action Sheets 的区别

  • Pop Menus 指向性比较明确,在触发控件附近显示,使用起来比较便捷,并且呈现形式对用户打扰较小。
  • Action Sheets 从屏幕底部弹出后可能会挡住触发控件,或者相距较远,点击后需移动视线到屏幕下方,并且所占屏幕空间较大,加上底部遮罩层的视觉样式,对用户打扰较大。
  • 在手机端,以上区别影响较小。所以,一般情况下,当使用场景为「启动任务」或「筛选内容」时,既可以使用 Pop Menus,也可以使用 Action Sheets。
  • 在 iPad 等较大的屏幕上,则一般使用 Pop Menus。


5.3.2. Bottom Menus 底部菜单

(1) 以 “底部模态面板” 的形式承载菜单功能。从底部向上滑动出现的面板,可承载的菜单项较多。
(2) 模态。向下滑动面板、点击「关闭」按钮或遮罩层关闭面板。
(3) Action Sheets 和 Activity Views 可以看作一种特定的底部菜单。
(4) 底部菜单用于筛选内容时:
单个筛选条件:选中选项后,自动关闭面板。
多个筛选条件:一般包含「重置」和「确定」按钮,选择菜单项后,点击「确定」才关闭面板,点击「重置」可清空所有已选条件。


5.3.3. Top Menus 顶部菜单

(1) 以 “顶部弹出层” 的形式承载菜单功能。
(2) 模态。点击遮罩层可关闭弹层。
(3) 通常与顶部 tab 结合,切换 tab 直接关闭当前弹层,同时显示新的弹层。
(4) 常用于筛选内容
Tab 下仅包含一个筛选条件:选中选项后,自动关闭弹层。
Tab 下包含多个筛选条件:一般包含「重置」和「确定」按钮,选择菜单项后,点击「确定」才关闭弹层,点击「重置」可清空所有已选条件。


5.3.4. Side Menus 侧边菜单

(1) 以 “侧边弹出层” 的形式承载菜单功能。
(2) 模态。点击遮罩层可关闭弹层。
(3) 抽屉式的侧边菜单可承载更多筛选条件更多选项。常见的使用场景是,当筛选条件比较复杂时,与上文的「5.3.3. Top Menus 顶部菜单」结合,将较高频使用的筛选条件用「tab + 顶部菜单」的形式呈现,其他更多的较低频的条件都放在侧边菜单中。


5.4. iOS 官方提供的其他菜单类型

5.4.1 Edit Menus 编辑菜单

(1) 长按或单击文本视图、网页或图片视图中的元素来选择内容并显示编辑选项,例如复制和粘贴。
(2) 自定义命令的数量不宜过多,太多选择会让⽤户感到困惑。
(3) 保持自定义命令名称简短。命令名称应该是动词或简短的动词短语,简洁地描述要执行的动作。
(4) 如果未选择任何内容,则菜单不应显示如 “复制” 或 “剪切” 等操作选项。同样,如果已选择某些内容,则菜单不应显示 “选择” 选项。
(5) 不要使⽤与编辑菜单相同的功能的其他控件。提供多种⽅式来启动操作会导致⽤户体验不一致并导致混淆。例如,如果应用中允许⽤户使⽤菜单复制内容,请不要使用复制按钮。


5.4.2 Context Menus 情境菜单

(1) iOS 13 之前叫「Peek and Pop 预览弹出功能」,只能在支持 3D Touch 的设备上使用。主要用于快速预览内容;如果 app 进行了相应的支持,还可以通过向上轻扫预览视图唤出相关的操作选项。
(2) iOS 13 及 iOS 13 之后,所有设备都可使用「Context Menus 情境菜单」。长按或 3D Touch 均可唤出情境菜单,但 3D Touch 的速度会更快。并且,唤出情境菜单时,相关操作菜单会同时呈现,无需进一步操作。
(3) 为 app 当中所有可能产生相关操作的内容对象添加情境菜单功能。这样既便于操作,也利于发现所有可执行的功能。
(4) 情境菜单虽然很便捷,但并不是所有用户都能始终想到去使用它。所以,情境菜单中提供的功能也应该能够在界面中的其他地方被访问到


5.4.3. Home Screen Quick Actions 主屏幕快捷操作

(1) 主屏幕快捷操作是 iOS 独有的交互形式,只在主屏中使用,用于快速执行应用的常用任务。通过 3D Touch 唤起 app 指定的快捷操作菜单。只需比 “长按” 更重一些的按压,就能看到高频操作菜单。
(2) 显示符合上下文情景的操作选项,并用通用的文案描述。
(3) 尽可能地减少选项数量,只显示最有意义的操作
(4) 使用标准手势唤起菜单。
(5) 根据唤起的位置,自动调整菜单的位置。



6. Dialogs 对话框

6.1. Alerts 警告框

6.1.1. 简介

警告框用于传达与 app 或设备状态相关的重要信息,并且通常需要得到用户的反馈。
警告框的内容包括标题,描述消息(可选)、一个或多个按钮以及输入框(可选)。除这些元素外,警告框的外观样式是不可更改的。

6.1.2. 特点及使用场景

(1) 尽量避免使⽤警告框
警告框⼗分影响⽤户的操作体验,只应该在重要的场景下使用。例如,确认购买和破坏性的操作(如,“删除”),或,通知用户有关 app 和设备的问题(警告、预警之类的问题)。(一般,系统主动发出的重要通知就是使用 Alerts。)
(2) 主要有以下几种类型。
① 根据按钮数量分

  • 一个按钮:通常用于通知,因为它不提供其他更多的操作选择。
  • 两个按钮:官方建议采用的警告框,它提供了两个选择,方便用户做出决定。
  • 三个按钮:按指南中的建议,三个及三个以上按钮会让选择变得复杂,而且按钮数量过多可能出现需要滚动的情况,会造成不好的用户体验,这种情况下可以考虑使用 Action Sheets。但其实官方组件中还是有三个按钮的警告框,比如,获取用户授权时的警告框。



② 包含应用评分的警告框



③ 包含输入框的警告框



④ 包含选项选择的警告框

除了以上样式的警告框,这里根据我们的产品的具体情况,增加了一种包含选择列表的警告框,通常用于在提交重要操作之前进行选择并确认。选择列表可以是单选列表(单选框)或者多选列表(复选框)。对于多选列表,一般未选择任何选项时,提交按钮为禁用状态。
(3) 除了以上提到的操作数量过多的情况可考虑使用 Action Sheets 之外,一般情况下的操作确认也可用 Action Sheets 代替,比如,点击「取消关注」后的操作确认(不算危险操作,一般不会造成严重后果)。
(4) 按指南中的建议,在显示警告框的情况下,若用户切回到手机主屏幕,相当于按下「取消」按钮。


6.1.3. 设计规范

(1) 模态。不提供关闭按钮,不支持点击遮罩层关闭警告框,用户必须作出操作决策。("取消" 不是 “关闭”,“取消” 是我选择取消,不执行这个动作,“关闭” 是我不做任何选择直接关闭,没说到底执不执行这个动作。)
(2) 确保警告框在竖屏和横屏中均显示正常。
设计时需考虑警告框的最大高度,保证竖屏和横屏模式下文字都能完整显示,不需要进行滚动。
(3) 标题
① 使用简短的描述性标题。
② 可以使⽤疑问句或简短的陈述句来传递更准确的信息。
③ 尽量避免单个词的标题,例如,错误、警告等。这类标题几乎不能提供任何有用信息。
④ 尽量将标题控制在⼀行以内。
⑤ 如果标题是完整的句⼦,句末需添加适当的标点符号。如果标题是句⼦⽚段,不要使用表示结束的标点符号。
(4) 描述信息
如果能⽤标题表达清楚,就不要增加额外的描述信息。
② 如果一定要增加描述信息,请使⽤完整的短句。
③ 尽量将句⼦控制在一、两行以内,并在句末添加适当的标点符号。
(5) 按钮
① 为按钮设计简短而逻辑清晰的文案。
② 尽可能使用与警告文案直接相关的动词或动词词组,如「View All 查看全部 」、「Reply 回复」和「Ignore 忽略」等。如果是简单的通知,也可以使用「OK 好的 / 我知道了」。避免使用「Yes 是」或「No 否」。
③ 强化会产⽣破坏性操作的按钮。如,「删除」应采用 “负向” 的视觉样式,以表警示。
④ 尽量避免对警告按钮做出解释。如果警告框的文本和按钮标题内容传达的信息⾜够明确, 就不需要解释按钮的作⽤。
通常来说,取消按钮放在左边,右边的按钮是用户最有可能点击的按钮,即否定性操作放左边,肯定性操作放右边。
(6) 文案
① 避免出现指责、侮辱的语气。
② 避免出现 “你”,“你的”,“我”,“我的” 这类词语,因为这类词汇有时候会给人生疏和趾高⽓昂的感受。
③ 不用刻意避免在警告框中使用消极负面的文案。⽤户知道警告框弹出是出现了问题和危险的情况。只要语⽓友好,直截了当的传达消极的消息会比表意模糊的积极消息更好。


6.2. Custom Dialogs 自定义对话框

(1) 可视为系统原生的 Alerts 的变形。
(2) 常见于运营宣传、用户引导等场景。
(3) 可进行各种样式自定义,具有更强的视觉表现。可包含更多其他的操作,具体视场景而定。
(4) 模态。通常点击遮罩层可关闭对话框,同时也包含关闭按钮或其他可退出模态的按钮,这样用户一目了然地知道如何关闭对话框。



7. Modal Sheets 模态面板

7.1. Default Modal Sheets 默认模态面板

7.1.1. 简介

模态面板从屏幕底部向上滑出并覆盖屏幕,用途是切换任务状态。iOS 13 之后默认的模态面板样式是 “卡片风格的模态面板”,可用于不包含复杂任务的、非沉浸式的模态内容。


7.1.2. 呈现样式

(1) 卡片样式,部分覆盖了底层内容,未覆盖的区域变暗,以防止与它们交互。
(2) 在当前卡片的后面可以看到父视图或前一张卡片的顶部边缘,以帮助人们记住打开该卡片时暂停的任务。
(3) 卡片风格的好处在于,你可以瞥见面板下方的界面环境,这样你便可以意识到原本的任务流程或模式仍然在进行当中。(过去的全屏模态视图很容易使人们忘记之前的任务进程。)


7.1.3. 退出模态的方式

(1) 对不包含滚屏内容的面板,在卡片上的任意位置向下轻扫可关闭卡片面板;对包含滚屏内容的面板,向下轻扫会先使内容回滚到顶部,然后再继续下拉才会关闭整个面板。
(2) 无论是否包含滚屏内容,从卡片顶部向下滑动都可以直接关闭面板。
(3) 通过点击按钮关闭面板。
(4) 如果面板中包含需要通过纵向轻扫进行操作的控件,或是包含必须进行操作决策的逻辑,那么任何下拉关闭的操作都将被禁用,面板会自动弹回到默认的位置。譬如,当我们必须通过点击「取消」或「添加」按钮来结束当前逻辑状态的时候。
(5) 对于必须在结束模态之前完成操作决策的情况,可以通过呈现 Action Sheets 来禁止卡片的关闭,同时与用户进行操作确认。


7.1.4. 为模态面板提供按钮

(1) 可视化的按钮可以一目了然地帮助人们意识到面板可以被关闭。
(2) 这对于可访问性设计原则来说也是必需的。
(3) 此外,人们可能一时还无法习惯于通过手势来关闭面板,或是根本不想进行手势操作。
(4) 对于包含滚屏内容的面板来说,直接点击按钮进行关闭会更加便捷。
(5) 明示着「确认」和「取消」逻辑的可视化按钮还可以帮助人们快速理解有哪些选项可供执行。


7.2. Custom Bottom Sheets 自定义底部面板

7.2.1. 简介

现在,很多应用都开始使用卡片风格的底部模态面板,iPhone 上的原生应用也有很多使用半屏底部模态面板的场景。
底部模态面板可用于展示更多额外的内容,减少页面跳转。例如,上文的「自定义选择器」等等。


7.2.2. 退出模态的方式

与系统默认的卡片模态面板退出方式一样,但除此之外,一般还可通过点击遮罩层退出模态



8. Full-screen Modal Views 全屏模态视图

8.1. 简介

全屏模态视图会覆盖整个屏幕,即前一个视图会被完全覆盖,因此有更多的屏幕空间来展示内容,并且使视觉干扰降至最低。通过点击「取消」或「完成」按钮来取消全屏模式视图。


8.2. 使用场景

(1) 沉浸式内容,如视频、照片或相机视图等。
(2) 使用全屏展示会更好的复杂任务,如标记文档或编辑照片等。



9. 总结对比

9.1. 所有控件总览


9.2. 部分控件对比



10. 模态情境的使用

10.1. 使用建议

(1) 模态一般用于切换任务流程。
例如,在「日历」app 中,浏览日程列表里所有日程和浏览某个特定日程的详情,都属于 “浏览”,此时,进入日程详情就不需要使用 “模态”;而当需要创建或编辑日程事项时,就会进入 “编辑” 模式,此时,就需要用到模态面板,让用户意识到任务流程的变更。
(2) 尽可能减少应用中的模态体验,通常,仅在以下情境考虑使用模态:
① 必须引起用户关注的时候。
② 一个独立的任务需要完成或者很明确需要被放弃,为了避免在模棱两可的状态下遗漏用户信息的时候。
(3) 始终提供明显、安全的退出模态的方式。
(4) 确保用户在退出模态视图时可以预期操作的结果。
(5) 保证模态任务简单、简短和高度聚焦。
① 如果一个模态任务必须包含不同视图的子任务,确保给用户一个独立、清晰的导航路径。
② 一个任务需要多层级的模态视图时,尽可能避免在下级视图中添加「完成」按钮。否则可能造成困惑,用户会分不清点击「完成」按钮是完成这个视图中任务的一部分,还是整个任务。


10.2. 可替代方案

除了尽可能减少不必要的模态体验外,在 iOS 的设计指南中还提到了,要尽可能地将状态改变或其他类型的反馈信息放在界面中,最好是,用户在不进行操作、不跳出当前内容、不被打扰的情况下,就能获得需要的信息。



以下这些反馈设计方案,既可以明确、及时告知用户任务状态(如操作结果、上传进度等等),又降低了对用户的打扰程度,不影响用户对其他内容的浏览和操作。
(1) 将反馈(如加载进度等)放在按钮上。



(2) 适当添加动效。(合适的动效还可提升使用时的愉悦感。)



(3) 将不需要打断用户操作的图片、视频的上传、转码等进程放到后台进行。(这个需要根据具体的功能、业务和开发实现技术等因素综合确定。)



(4) 页面内提示。表单校验使用实时校验,并在出错项附近显示错误提示。



(5) 其他交互方式:合理地使用推挤等交互形式。




  1. 文中配图展示的控件样式仅为参考,实际运用中可根据具体产品功能、业务场景、设计风格等进行设计。
  2. 此次规范梳理的过程中,我在网上查阅及参考了以下官方指南与文章,感谢这些平台和作者~

iOS:Human Interface Guidelines(Apple Developer)
Material Design(Google)
Android:Documentation for app developers(Google Developers)
Ant Design Mobile(蚂蚁金服)
支付宝开放平台文档(蚂蚁金服)
支付宝小程序设计文档(来源:书栈网)

MBProgressHUD(作者:Jonathan George;来源:Github)
iphone - What is HUD VIEW?(来源:Stack Overflow)
UIProgressHUD(作者:Dustin Howett;来源:iPhone Development Wiki

Modal & Nonmodal Dialogs: When (& When Not) to Use Them(作者:Therese Fessenden;来源:NN/g)
你真的了解这些交互控件吗?(作者:johnnylhj;来源:人人都是产品经理)
移动弹窗基础知识浅析——iOS弹窗体系(作者:常天;来源: TXD技术体验设计公众号)
各种「弹窗」有学名,从此不再分不清(来源:掘金)
实用干货!UI设计师需要了解的 APP弹窗体系(来源:优设网)
iOS:自定义模态(译文)(作者:半木zxy;来源:知乎)
弹窗、模态、提示、浮层,这几位是什么关系?(来源:知乎)
模态是一个大多数设计师不能完全理解的UX概念(作者:花火圆桌;来源:知乎)
CSS 命名之Dialog, Modal, Popup, Popover, Lightbox 等的区别(作者:Jeff;来源:腾讯云云+社区)
terminology - What’s the difference between a Modal, Popup, Popover and Lightbox? (来源:Stack Exchange)
这个控件叫什么(作者:龙爪槐守望者;来源:知乎)
正确使用控件 - 确认弹框、全屏弹框和模态视图(作者:沐风与体验设计;来源:简书)
3分钟带你掌握11个最常用的交互控件(作者:沐风与体验设计;来源:简书)
iOS和Android规范解析——简易菜单、简易对话框和弹出框(作者:沐风与体验设计;来源:简书)

5000字,总结App加载设计(作者:一点优秀;来源:人人都是产品经理)
toast 吐司提示放在屏幕哪个区域比较好?(来源:知乎)
Can an Android Toast be longer than Toast.LENGTH_LONG?(来源:Stack Overflow)
Designing Toast Messages for Accessibility(作者:Sheri Byrne-Haber;来源:Medium)
人机工程学在交互设计中的运用(作者:XUE.百度;来源:人人都是产品经理)




最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,313评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,369评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,916评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,333评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,425评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,481评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,491评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,268评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,719评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,004评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,179评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,832评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,510评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,153评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,402评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,045评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,071评论 2 352