【发布时间】:2025-12-02 03:40:02
【问题描述】:
我目前有一个文件上传系统,目前我有一个按钮可以将用户带到下一页,但即使用户没有上传任何内容,这也是可见的,如果用户按下它,危险就在这里在上传任何东西之前它会抛出一个错误并且看起来很糟糕,所以我想要做的是隐藏这个按钮,直到文件上传成功,有什么想法吗?
<p:fileUpload widgetVar="upload" fileUploadListener="#{fileUploadController.handleFileUpload}"
mode="advanced"
multiple="false"
update="messages"
label="Select File"
sizeLimit="100000000"
allowTypes="/(\.|\/)(gif|jpe?g|png|doc|docx|txt|pdf|html)$/"
auto="true"/>
<!-- selected auto="true" this has been selected to prevent user error as was discovered
when testing, some users pressed the upload button and wondered why nothing worked instead of
select file, now this stops this -->
<p:growl id="messages" showDetail="true"/>
Please press the button below once you have uploaded the file, to continue
<p:commandButton action="#{navigationBean.naviagtion}" value="Next" ajax="False"/>
下一步操作的命令按钮是我希望在文件上传完成之前禁用的按钮
编辑:
<p:commandButton action="#{navigationBean.naviagtion}" value="Next" ajax="False" disabled="#{!fileUploadController.UploadComplete}"/>
是我的命令按钮,它指向fileUploadContoller,这是文件上传等发生的地方,
问题是当我运行应用程序时,我总是在页面加载时获得一个实时按钮
我在我的 fileUploadController 中添加了一个布尔值:
public void handleFileUpload(FileUploadEvent event) {
//System.out.println("DesintationPDF : " + destinationPDF);
System.out.println("called handle file");
System.out.println("Destination is : " + configProp.getProperty("destination"));
FacesMessage msg = new FacesMessage("Succesful", event.getFile().getFileName() + " is uploaded."); //Displays to user on the webpage
FacesContext.getCurrentInstance().addMessage(null, msg);
try {
copyFile(event.getFile().getFileName(), event.getFile().getInputstream());
} catch (IOException e) {
//handle the exception
e.printStackTrace();
}
}
public boolean isUploadComplete() {
return uploadComplete;
}
public void setUploadComplete(boolean uploadComplete) {
this.uploadComplete = uploadComplete;
}
但还是报错
编辑 2:
<p:commandButton action="#{navigationBean.naviagtion}" value="Next" disabled="#{!fileUploadController.uploadComplete}"/>
控制台
INFO: Upload complete value before copy file false
INFO: upload complete value is : true
所以它正在将值更改为 true
但没有将按钮更改为实时
【问题讨论】:
-
上传完成后如何禁用按钮并启用它?对我来说似乎比突然渲染它更直观。我还建议您使用 PrimeFaces,因为它很棒。 (但这只是额外的事情)
-
这将是一个完美的解决方案,我目前正在使用 primefaces 来创建文件上传,并且按钮也是 primefaces,我将如何禁用并重新启用它?将发布我当前设置的代码
-
#{navigationBean.naviagtion}"里面可能有错别字。 -
#{navigationBean.naviagtion}"指向我拥有的一个 Java bean,它可以将用户带到另一个页面,目前运行良好 -
属性名为
naviagtion?不是navigation?
标签: java jsf file-upload primefaces