我一直在尝试使自己的selectOneMenu内容(取决于另一个选择的值)遇到麻烦。第一个的内容来自我的数据库中的一个表,并且运行良好,但是第二个的内容应该来自另一个表,但是我无法使其工作。这是我的index.html,我只是在尝试证明其工作原理:

        <h:outputLabel value="Estado" styleClass="requiredLbl"/>
        <p:selectOneMenu id="Estado" value="#{beanInscripcion.id_estado}" valueChangeListener="#{beanInscripcion.buscarMunicipios(event)}" >
            <f:selectItem itemLabel="Elegir Estado" itemValue="" />
            <f:selectItems value="#{beanInscripcion.estados}"
                           var="edo" itemLabel="#{edo.nombre_estado}" itemValue="#{edo.id_estado}" />
            <p:ajax update="Municipio"  listener="#{beanInscripcion.buscarMunicipios(event)}" />
        </p:selectOneMenu>
        <p:separator />
        <h:outputLabel value="Municipio" styleClass="requiredLbl"/>
        <p:selectOneMenu id="Municipio" value="municipio">
            <f:selectItems value="#{beanInscripcion.municipios}"
                           var="mun" itemLabel="#{mun.nombre_municipio}" itemValue="#{mun.nombre_municipio}" />
        </p:selectOneMenu>

这是我的Bean部分,应该获取第二个菜单的内容:
@ManagedBean(name = "beanInscripcion")
@ViewScoped
public class BeanInscripcion implements Serializable {

    static String strURL;
    private List<Estado> estados;
    private List<Municipio> municipios;
    private int id_estado;
    public BeanInscripcion() throws SQLException{
            estados = new ArrayList<Estado>();
            buscarEstados();
    }

    public void buscarEstados() throws SQLException {
        Connection connection = getConnection();
        Statement statement = connection.createStatement();
        ResultSet result = statement.executeQuery("SELECT * FROM estado");
        result.beforeFirst();
        while (result.next()) {
            Estado estado = new Estado();
            estado.setId_estado(result.getInt("id_estado"));
            estado.setNombre_estado(result.getString("nombre_estado"));
            estados.add(estado);
        }
    }

    public void buscarMunicipios() throws SQLException {
        Connection connection = getConnection();
        Statement statement = connection.createStatement();
        ResultSet result = statement.executeQuery("SELECT id_municipio, nombre_municipio FROM municipio WHERE Estado_id_estado = '" + id_estado + "'");
        result.beforeFirst();
        while (result.next()) {
            Municipio municipio = new Municipio();
            municipio.setId_municipio(result.getInt("id_municipio"));
            municipio.setNombre_municipio(result.getString("nombre_municipio"));
            municipios.add(municipio);
        }
    }

    public Connection getConnection() {
        try {
            strURL = "jdbc:mysql://localhost:3306/mydb";
            Class.forName("com.mysql.jdbc.Driver");
            return DriverManager.getConnection(strURL, "root", "root");
        } catch (SQLException ex) {
            return null;
        } catch (ClassNotFoundException ex) {
            return null;
        }
    }

    public List<Estado> getEstados() {
        return estados;
    }

    public void setEstados(List<Estado> estados) {
        this.estados = estados;
    }

    public List<Municipio> getMunicipios() {
        return municipios;
    }

    public void setMunicipios(List<Municipio> municipios) {
        this.municipios = municipios;
    }

    public int getId_estado() {
        return id_estado;
    }

    public void setId_estado(int id_estado) {
        this.id_estado = id_estado;
    }
}

我已经为此工作了几个小时,但仍然一无所获,我真的很着急,如果能在这里给我一些帮助,我将不胜感激。非常感谢您:D

最佳答案

value="municipio"中的

  • <p:selectOneMenu id="Municipio" value="municipio">意味着该下拉列表中的值将永远不会改变,因为您已经有效地将该字段上的值硬编码为municipio(甚至会失败转换)。 value属性应绑定(bind)到支持bean变量,如
      <p:selectOneMenu id="Municipio" value="#{beanInscripcion.municipio}" >
        <f:selectItems value="#{beanInscripcion.municipios}"
                       var="mun" itemLabel="#{mun.nombre_municipio}" itemValue="#{mun.nombre_municipio}" />
    </p:selectOneMenu>
    

    并在您的后备 bean 中
       Municipio municipio;
      //getter and setter
    
  • event中删除参数<p:ajax update="Municipio" listener="#{beanInscripcion.buscarMunicipios(event)}" />。它应该是
    <p:ajax update="Municipio"  listener="#{beanInscripcion.buscarMunicipios}" />
    
  • 删除valueChangeListener="#{beanInscripcion.buscarMunicipios(event)}"。没必要,因为您已经有一个<p:ajax/>事件定义了
  • 最终,由于您尚未为该Municipio定制类型创建JSF Converter,因此最终会遇到提交该表单的问题。如果您在选择的组件中使用的不是String类型,则这是强制性的。查看转换器/转换here
  • 的简短介绍

    09-16 12:20