我一直在研究CRUD应用程序,我需要将数据从数据库导出到csv文件。为了导出,我不得不以以下代码所示的方式禁用ajax:
<p:commandButton value="Export" ajax="false" action="myController.export"/>
在调用的方法中,我创建文件并通过OmniFaces实用程序方法下载该文件:
Faces.sendFile(file, true);
使用相同的方法,我检查实际上是否有任何数据,并且如果没有任何数据,则显示警告对话框:
RequestContext.getCurrentInstance().showMessageInDialog(new FacesMessage(FacesMessage.SEVERITY_WARN, "Warning!", "No available data for export."));
现在,尽管所有这些操作都能按预期工作,但是问题在于,由于禁用了ajax,因此无法动态显示对话框,并且需要重新加载页面。如果启用了ajax,则会动态显示对话框,但文件下载不会开始。
我一直在尝试通过使用Monitor
download
或通过强制单击第二个按钮来解决此问题,但是到目前为止,我在此问题上尚未取得任何进展。
有没有普遍接受的解决此类问题的方法?
有没有普遍接受的解决此类问题的方法?
基本上,您首先要触发ajax请求,并在其oncomplete检查中是否成功,然后触发同步请求以下载文件(请注意,您无法使用ajax下载文件)。您可以使用FacesContext#validationFailed()
(或OmniFaces
Faces.validationFailed()
)标记验证失败状态,该状态可以通过args
PrimeFaces在oncomplete
函数上下文中注入的对象获得(请注意,与ajax相关的属性(例如,oncomplete
禁用ajax时不起作用))。
像这样:
<p:commandButton
value="Export"
action="#{bean.export}"
oncomplete="if (args && !args.validationFailed) PF('download').jq.click()" />
<p:commandButton
widgetVar="download"
styleClass="ui-helper-hidden"
action="#{bean.download}" ajax="false" />
public void export() {
// Prepare file locally.
if (fail) {
// Show message your way and then set validation failed as below.
Faces.validationFailed();
}
}
public void download() throws IOException {
Faces.sendFile(file, true);
// Delete local file afterwards?
}
请注意,<p:commandButton>
正在使用隐藏而不是<p:remoteCommand>
后者不支持ajax="false"
。
我有一个服务类,用 我想在启动服务时显示一条自定义消息,内容如下 有办法做到这一点吗?由于bean没有加载,我不能使用或类似的东西
问题内容: 我有一个表格,如果单击“提交”,则需要显示验证错误消息。 这是一个工作的家伙 用户开始进行更改时,验证工作正常。但是它不会显示任何错误消息。如果单击“提交”而不输入任何内容。 有实现这个的想法吗?或者以其他方式如何在单击“提交”按钮时使每个输入字段$ dirty 问题答案: 我在http://jsfiddle.net/thomporter/ANxmv/2/上找到了这个小提琴,它巧妙地进
问题内容: 我有一个带有两个输入文本框的表单,并且我包括了两个的jQuery验证规则: 我用过了: 突出显示错误控制。现在的问题是,在以下情况下,两个输入文本框都保持突出显示(背景色:红色): 在文本框1中输入少于5个字符的文本 将文本框2留空 点击提交 两个输入文本框的背景都将更改为红色(正确) 现在,在文本框1中输入一个包含6个字符的文本(有效输入) 将文本框2留空 点击提交 两个文本框的背景
因此,很明显,它识别出输入的名称太短,但我在视图中没有得到任何错误消息,正如这里所预期的:。
问题内容: 我在隐藏的文本区域中有一些文本。单击按钮后,我希望提供文本作为文件下载。是否可以使用AngularJS或Javascript? 问题答案: 您可以使用进行类似的操作。 在您的控制器中: 为了启用URL: 请注意 每次调用createObjectURL()时,都会创建一个新的对象URL,即使您已经为同一对象创建了一个URL。当不再需要它们时,必须通过调用URL.revokeObjectU