- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们有一些搜索页面需要运行大量数据,并且需要一段时间才能完成。当用户单击搜索按钮时,我们希望不允许他们再次提交搜索结果。
是否有在 JSF 中进行“双击”检测/预防的最佳实践?
PrimeFaces 组件似乎可以做我们想要的事情,因为它会在单击搜索按钮和搜索完成之间的一段时间内禁用 UI,但是我们可以使用更通用的策略(也许不依赖于 PrimeFaces 的东西)?理想情况下,在搜索完成之前,对该按钮的任何单击都将被禁用或忽略。我们不一定需要禁用整个 UI(因为 blockUI 允许您这样做)。
最佳答案
如果您仅使用 ajax 请求,则可以使用 jsf.ajax.addOnEvent
JSF JavaScript API 的处理程序。以下示例将应用于 type="submit"
的所有按钮.
function handleDisableButton(data) {
if (data.source.type != "submit") {
return;
}
switch (data.status) {
case "begin":
data.source.disabled = true;
break;
case "complete":
data.source.disabled = false;
break;
}
}
jsf.ajax.addOnEvent(handleDisableButton);
或者,如果您仅在特定按钮上需要此功能,请使用 onevent
<f:ajax>
的属性.
<h:commandButton ...>
<f:ajax ... onevent="handleDisableButton" />
</h:commandButton>
如果您还需要在同步请求上应用此功能,那么您需要考虑在onclick
期间禁用按钮时的情况。 ,然后按钮的 name=value
对不会作为请求参数发送,因此 JSF 将无法识别该操作并调用它。因此,您应该仅在浏览器发送 POST 请求之后才禁用它。没有用于此目的的 DOM 事件处理程序,您需要使用 setTimeout()
点击后约 50 毫秒禁用按钮。
<h:commandButton ... onclick="setTimeout('document.getElementById(\'' + this.id + '\').disabled=true;', 50);" />
这只是相当脆弱。对于速度慢的客户端来说,它可能太短。您需要增加超时时间或转向其他解决方案。
也就是说,请记住,这只能防止通过网页提交时的重复提交。这不会阻止编程 HTTP 客户端(例如 URLConnection
)的双重提交、Apache HttpClient、Jsoup 等。如果您想在数据模型中强制执行唯一性,那么您不应该阻止重复提交,而应该阻止重复插入。这可以在 SQL 中通过输入 UNIQUE
轻松实现。对感兴趣的列的约束。
关于jsf - 如何在 JSF 中防止双击,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10756426/
我在很多论坛和问题上搜索,但似乎没有人问如何在 Angular/ionic 2 中双击或双击? 在 ionic v1 中,它可以通过 双击 使用(参见 http://ionicframework.co
我有一个 GridView,我想在其中检测列表中项目的双击事件,我按如下方式执行:
我试图让我的程序识别 NSCollectionView 的双击。我尝试遵循本指南:http://www.springenwerk.com/2009/12/double-click-and-nscoll
我正在使用依赖属性来显示一个窗口,双击一个项目。 不确定这是 WPF 的特定错误还是我做错了什么。 如果我双击滚动条或列标题。它会触发双击命令。 在 ths 链接上尝试了解决方案 WPF ListVi
我只是想让我的 uitextview 在用户双击它时可编辑。 但在我的代码中它只能工作一次。隐藏键盘后双击停止像我想要的那样工作。它只显示“复制并定义”弹出窗口,如果我第二次尝试...... 也许“t
对于学校项目,我必须在 JList 上使用 ListSelectionListener(LSL)。我知道 LSL 会响应鼠标单击和鼠标释放。但对于该项目,我必须让它响应双击。有没有办法让 LSL 对此
当尝试通过双击从列表中选择项目时,它会为两个列表选择一次,但在单击选择后!!! listScrollPanel.setViewportView(categoryList); subCa
我读过这个How to distinguish between mouseReleaseEvent and mousedoubleClickEvent on QGrapnhicsScene还有这个Di
我有两个列表与 jQuery UI 中的connectedSortable 连接,但我想添加一个功能,能够双击一个项目并将其移动到另一个列表,但我真的不知道如何去做。 最佳答案 $j('#list
我正在使用 DevExpress xtraScheduler 10.2 如何处理 xtraScheduler 中的双击事件(仅在约会而非单元格上)? 我不想显示任何 appointmentedit 表
在这方面遇到了一些麻烦。所以我的公司想要应用程序的左抽屉菜单。具体来说,菜单的控件也附加在每一行中。即每一行都有单独的订单号和附加的操作按钮。单击“操作”按钮时,抽屉会打开以执行各种操作。现在的问题是
我尝试打开一个 UIAlertView,其中有两个 textfield 以及我选择的单元格中的文本。我使用这段代码: -(void)tableView:(UITableView *)tableView
以下是我的代码;我没有被 didDoubleTapMap 解雇。 UITapGestureRecognizer *doubleTap = [[UITapGestureRecognizer alloc]
所以我有一个表单,双击一个字段会弹出一个自定义模式窗口。模态窗口上的“保存”和“取消”按钮具有调用模态窗口层上的hide() 的“单击”事件。然而,我们的一些用户自然会双击东西。双击保存或取消按钮会触
我正在为 Google 地球开发此解决方案。我有一个标题,其中包含使用 CSS 创建的按钮,单击这些按钮会触发 KML 的加载。我遇到的问题是,如果用户再次单击该按钮,它会再次加载相同的 KML。我需
当我双击 ListView 项目时,我收到了 DoubleTapped 事件。 但我不确定如何获取执行点击的所选项目。ListView.Selecteditem 没有给我点击的项目。 请帮忙。 最佳答
我目前有一个 UISwitch,它在打开和关闭时分别递增和递减一个计数器。 当计数器为 0 时,计数器不会递减。从功能上讲,这工作得很好,但是我注意到一个错误,想知道是否有人遇到过这个问题。 本质上,
我试图找出如何处理鼠标左键(或任何)双击。但是我找不到任何关于它的信息。 有人能帮帮我吗?我不想编写自己的双击处理程序。 GLFW_REPEAT 不适用于鼠标按钮。 最佳答案 编写自己的双击处理程序有
我想使用 GestureDetector 的 tap 方法检测 libgdx 中的双击。手势监听类。过去两天我在网上搜索过,但找不到如何操作的示例。我知道该方法有一个“计数”变量,但我不知道如何使用它
如何识别 UIButton 上的双击? 最佳答案 为控件事件UIControlEventTouchDownRepeat添加一个target-action,只有当touch的tapCount为2时才做a
我是一名优秀的程序员,十分优秀!