是否可以使用 EL 启用/禁用按钮?我想使用提交按钮来切换(启用/禁用)登录按钮。complex.process 方法被调用。
此外,进度条并没有真正显示任何有意义的指示,尽管我看到填写姓名、电话、通过电子邮件将其发布到服务器。
我在 win 7 上使用 firefox 19、jsf 2.2m09、tomcat 7.0.35。
片段:
<form>
...
<input jsf:id="submit" type="submit" value="submit">
<f:ajax execute="@this" render="status" event="click" listener="#{complex.process}" />
</input>
<label jsf:id="status">#{complex.status}</label>
<button jsf:id="login" disabled="#{complex.status}">Login</button>
</form>
完整的代码如下所示,它显示了正确的数据正在呈现但按钮保持禁用状态。
小面:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:jsf="http://java.sun.com/jsf"
xmlns:f="http://java.sun.com/jsf/core">
<head jsf:id="head">
<title>Putting it all together </title>
<!-- script jsf:target="body" jsf:name="js.js"/>
<link jsf:name="css.css" rel="stylesheet" type="text/css" /-->
</head>
<body jsf:id="body">
<form jsf:id="form" jsf:prependId="false">
<label jsf:for="name">Name </label>
<input jsf:id="name" type="text" jsf:value="#{complex.name}">
<f:ajax execute="@this" render="progress"/>
</input>
<label jsf:for="tel">Tel </label>
<input jsf:id="tel" type="tel" jsf:value="#{complex.tel}">
<f:ajax execute="@this" render="progress"/>
</input>
<label jsf:for="email">Email </label>
<input jsf:id="email" type="email" jsf:value="#{complex.email}">
<f:ajax execute="@this" render="progress"/>
</input>
<label for="progress">Progress </label>
<progress jsf:id="progress" max="3">#{complex.progress} of 3 </progress>
<input jsf:id="submit" type="submit" value="submit">
<f:ajax execute="@this" render="status" event="click" listener="#{complex.process}" />
</input>
<label jsf:id="status">#{complex.status}</label>
<button jsf:id="login" disabled="#{complex.status}">Login</button>
</form>
</body>
</html>
托管豆:
package com.myco.bean;
import java.io.Serializable;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.faces.context.FacesContext;
import javax.faces.event.AjaxBehaviorEvent;
@ManagedBean
@SessionScoped
public class Complex implements Serializable {
public Complex() {}
private String name;
private String tel;
private String email;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getTel() {
return tel;
}
public void setTel(String tel) {
this.tel = tel;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
private String status = "disabled";
public void process(AjaxBehaviorEvent event) {
System.out.println("listener process called");
boolean s = false;
status = (status == "disabled" ? "" : "disabled");
if(status == "") s = false; else s = true;
//FacesContext.getCurrentInstance().getViewRoot().findComponent("form").findComponent("login").getAttributes().put("disabled", s);
}
public String isStatus() {
return status;
}
public String getStatus() {
System.out.println("getStatus:" + status);
return status;
}
public void setStatus(String status) {
this.status = status;
}
public String getProgress() {
int progress = 0;
if(name != null) {
progress++;
}
if(tel != null) {
progress++;
}
if(email != null) {
progress++;
}
return progress + "";
}
}
一些tomcat日志输出:
START PHASE RESTORE_VIEW 1
END PHASE RESTORE_VIEW 1
START PHASE APPLY_REQUEST_VALUES 2
END PHASE APPLY_REQUEST_VALUES 2
START PHASE PROCESS_VALIDATIONS 3
END PHASE PROCESS_VALIDATIONS 3
START PHASE UPDATE_MODEL_VALUES 4
END PHASE UPDATE_MODEL_VALUES 4
START PHASE INVOKE_APPLICATION 5
listener process called
END PHASE INVOKE_APPLICATION 5
START PHASE RENDER_RESPONSE 6
getStatus:disabled
END PHASE RENDER_RESPONSE 6