- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个 Web 应用程序,其中有一个模式面板/对话框弹出窗口来收集用户数据。面板中的表单变得很大,我们建议将表单拆分为多个选项卡,但我们的客户建议在模式面板中添加滚动条。
模式面板中的滚动条是否存在可用性问题?我认为这是一种不好的做法,但我想听听其他意见。
谢谢
格伦
更新:我将更详细地解释该场景。我们有一个搜索页面,可以在其中保存搜索结果项(复制到系统的另一个区域)。附加信息可以与此项目一起保存(例如附加注释、分配给其他存储桶 - 我无法详细说明)。当用户想要保存搜索结果项目时,他们可以检查一个或多个项目并单击保存按钮 - 这时我们的模式面板会弹出。
最初,用户被带到一个单独的页面,并且他们关注了一系列页面。我们的客户认为这很耗时,因此我们更改了页面以使用模式面板。
我不能 100% 确定使用模态面板是最好的设计,但这就是我们现在所拥有的。我欢迎任何其他想法。
最佳答案
好吧,我想问一下,如果你有一个这么长的模态表单,难道不应该将其制作成自己的页面吗?
我的意思是,模态对话的重点是告诉用户他需要知道的事情(这些信息通常被忽视并且很烦人),或者在继续之前从用户那里获取一些必要的信息。
您说您的表单用于收集用户输入。如果用户在继续操作之前必须输入某些内容(例如结帐流程的一部分或类似的内容),那么我认为最好将整个页面专用于该流程。
如果它更像是“在继续您正在做的事情之前先登录”之类的事情,那么我认为它作为自己的页面将您带回到该页面会更有意义填写完表格后,您就可以在输入之前就登录了。这就是 Stack Overflow 人工验证页面的工作原理。
如果它是一些烦人的内容,例如“向我们提供有关该网站的反馈”,那么它根本不应该是模态的,而应该是一个很容易被忽略的(我敢说吗?)弹出窗口。
模态对话确实应该尽可能简短。如果简洁是不可能的,并且对话确实必须是模态的,那么我认为创建一个必须先填充才能访问下一个页面的页面流会更有意义。就像结帐一样:您需要在添加运输信息之前将产品添加到购物车,并且需要运输信息才能确定运输成本。诸如此类的事情。
但是,如果不知道模态对话的确切性质,我无法准确告诉您哪种方式最好。
<小时/>编辑:啊哈!您的客户觉得这很耗时,是吗?在这种情况下,您应该进行非常快速且肮脏的实时可用性测试,看看哪种方法实际上更好。从大厅下面捕获一些人,向其中一些人展示模态方式(通过滚动)进行操作,并向其他人展示旧的(非模态)方式进行操作,看看他们会说什么。
(理想情况下,您正在录制 session 和屏幕,并且确保不要让您自己的个人偏好暴露出来。只需要求他们在您观看时使用系统,看看他们执行任务的情况如何。使用录音对两种方法进行计时,看看一种方法是否真的比另一种方法更快。)
您不应该做出违反规范的可用性决定(在这种情况下,规范是“大型表单值得拥有自己的页面”),而不确保它实际上以异常方式更可用。当谈到可用性时,规范通常是规范,因为它是可用的(但并不总是如此,这就是为什么你必须测试)。如果客户反击,你至少会有证据表明他们正在反对确凿的经验证据,证明他们想要的东西是愚蠢的。
不过,最终买单的还是客户。如果你不能让他们明白道理,那么你就必须充分利用他们告诉你的内容。如果表单必须处于模态对话框中,那么您至少可以尝试将非必要字段隐藏在折叠下(如果有非必要字段),以便大多数用户永远不必滚动。
确保无论用户滚动到何处,提交表单的按钮(或您需要对表单执行的任何操作)都是可见的。一个非常糟糕的主意是将所有必填字段放在顶部,然后强制用户向下滚动以点击提交按钮。这太粗鲁了。
关于usability - 模式面板中的滚动条,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2186640/
我有一个 Bootstrap 面板,里面有另一个面板。两者在面板标题中都有一个字形图标。默认情况下,面板是折叠的。当面板折叠时,将设置 glyphicon-unchecked。当我点击这个字形图标时,
使用 Grafana 时,我们会在某些电视上使用它。有谁知道制作它的方法,如果有人添加面板,更改布局等,它不仅会自动刷新数据,还会自动刷新实际仪表板? 我们真的厌倦了不断要求具有远程访问权限的人登录并
基本上,我试图让屏幕底部有 3 个按钮,然后在屏幕中间有一个包含文字的标签。但是,我似乎无法同时在 GUI 中同时拥有按钮和标签。我是一名初学者,对布局了解不多(即使我已经阅读过它们),因此任何帮助/
作为学校的类(class)作业,我们必须提出一个自定义项目,我选择了一个原本打算在 ActionScript 上编写的游戏创意,但决定在 Java 上插入它。最初进展顺利,游戏代码正常运行, Spri
我正在尝试使用 Java Graphics 制作一个生命模拟游戏,但是当运行我的代码时,屏幕的左侧三分之一是灰色的。我希望整个屏幕是白色的,黑色方 block 代表生命方 block 。我对所有 ja
下面是动态驱动的一个不错的“下拉面板”。 http://www.dynamicdrive.com/dynamicindex17/dddropdownpanel.htm 如您所见,它是一个面板,在打开时
所以我有这个函数 onDisplayError ,如果请求失败,每次都会调用它。这意味着如果用户按下保存按钮并且 3 个请求失败,我当前会收到 3 个弹出消息。我的目标是此函数检查我的弹出窗口是否已打
我正在尝试为我的一个类(class)制作一款游戏,但在实现一些我想做的事情时遇到了麻烦。本质上,我希望在同一个图形用户界面窗口中包含多个不同的部分。 据我了解,我会使用 JPanel 来创建这些不同的
我目前正在测试这种类型的面板 jquery: http://codyhouse.co/gem/css-slide-in-panel/ 但是当我想检测从顶部滚动以显示一个 div 时:没办法:( 一种检
我可能正在搜索错误的问题,但我找不到这个问题的答案。 我有一个 AutoScroll 设置为 true 的面板。控件动态添加到面板。我需要在滚动条可见时触发一个事件,但我找不到这样的事件。 如有任何建
我有一堆 Bootstrap 面板,其中一些是相互关联的。有点像 Panel A -> Panel B -> Panel C 当用户单击面板 B 时,将显示面板 C,当单击面板 C 时,将显示面板 D
我正在尝试开发一种带有指标的下拉列表,并相应地针对应该出现在仪表板上的选定指标特定面板。反之亦然,如果未选择指标,则面板应隐藏。 我找到了链接 http://search-devops.com/m/k
我有一个窗口,窗口里面有面板。我动态地向面板添加组件。这些组件采用“hbox”布局,以便它们水平排列。单击按钮后,我将在“hbox”布局中再向面板添加一行类似组件。这里的问题是我想在第一行下面添加第二
我使用 jQuery Accordion 将表单拆分为多个面板,并使用 jQuery 验证来检查所需字段。只要验证字段位于打开的面板中,它就可以很好地显示已验证字段中的错误。 举个例子。假设我有三个
我正在尝试检查我的面板是打开还是关闭。 我尝试过这样的: $(document).on('open', '.ui-panel', function(){ console.log('open');
我有一个面板,我想将其 float 在所有窗口之上并出现在所有空间中。这可以通过 轻松完成 [self.panel setLevel:kCGUtilityWindowLevel]; [self.win
我想在格子中的单个面板上叠加多个组,并且想要独立的回归线。 获得多个面板相当容易,每个面板都有一条使用条件因子的回归线: xyplot( Petal.Width ~ Petal.Length |
Delphi 有滑动(动画)面板组件吗? 例如可以在 Raize Components 中找到它(带有“热点”或隐藏/显示按钮的左侧面板)。 我不需要一个可调整大小的面板,而是一个可以从左向右水平平滑
我有一个 Bootstrap Accordion : 我想禁用非事件面板中的所有输入控件。仅验证事件面板。 我有一个检测事件选项卡的功能: $(".panel").on("show.bs.collap
我正在尝试将组件放入不同尺寸的面板中。但是,我意识到 GridLayout 将大小相同的部分分开。如何实现如下图所示 enter image description here import java.
我是一名优秀的程序员,十分优秀!