0

是否可以使用 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
4

0 回答 0