<f: ajax> Parent is not a component or type of ClientBehaviorHolder in one menu

I am trying to get a second selection method that will display depending on what was selected for the first value. Now I need to do this over 38 times for the form I am creating, but I want to see if I can get it to work on one question in the first place. Here is the code I've cut so far on the jsf page. The values ​​are the same for the remaining 38 questions. I just recreated the project and still the bean is currently empty, but I know that I should be able to at least see the form, first of all, what I hope to do so far before adding the values ​​and code.

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
      "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml"
          xmlns:h="http://xmlns.jcp.org/jsf/html"
          xmlns:f="http://java.sun.com/jsf/core" >

    <h:head>
    <title>QC-Form</title>

    </h:head>
    <h:body>
    <h1 class="title">QC Form</h1>
    <br/> <br/>

      <font face="comic sans MS" size="2" color="#33CCFF">
      <p><b>Enter the information below: </b> </p>
      </font>

    <h:form>

     <font face="comic sans MS" size="2"> 

     <b>Your initials: </b>  
        <h:inputText value="#{qcFormBean.techNameValue}"/><br/>
    <br/>

     <b>Model #: </b>  
    <h:selectOneMenu value="#{qcFormBean.modelValue}">
      <f:selectItem itemValue="3600" itemLabel="3600" />
      <f:selectItem itemValue="7200" itemLabel="7200" />
      <f:selectItem itemValue="8300" itemLabel="8300" />
      <f:selectItem itemValue="8400" itemLabel="8400" />
      <f:selectItem itemValue="8500p" itemLabel="8500p" />
      <f:selectItem itemValue="8800" itemLabel="8800" />
      <f:selectItem itemValue="9000" itemLabel="9000" />
      <f:selectItem itemValue="9008" itemLabel="9008" />
      <f:selectItem itemValue="9200" itemLabel="9200" />
      <f:selectItem itemValue="9300" itemLabel="9300" />
    </h:selectOneMenu><br/>
     <br/>

    <b>Date : </b>
     <h:outputText  value="#{currentDate}"/>
    <br/> <br/>


    <b>Serial #: </b>  
        <h:inputText value="#{qcFormBean.serialValue}"/><br/>
    <br/>

    <b>Customer Name: </b>  
        <h:inputText value="#{qcFormBean.customerNameValue}"/><br/>
    <br/>

    <b>Special Instructions: </b>  
        <h:inputText value="#{qcFormBean.specialInstructionsValue}"/><br/>    

    </font>

      <font face="comic sans MS" size="2" color="#33CCFF">
      <p><b>QC Process</b> </p>
      </font>

     <font face="comic sans MS" size="2"> 


     <b>1.Unit Serial number has been applied: </b>
     <h:selectOneMenu value="#{qcFormBean.unitSerialValue}">
      <f:selectItem itemValue="P" itemLabel="Pass or Not Applicable" />
      <f:selectItem itemValue="A" itemLabel="FAIL-Nonfunctional" />
      <f:selectItem itemValue="B" itemLabel="FAIL-Intermittent" />
      <f:selectItem itemValue="C" itemLabel="FAIL-Incorrect" />
      <f:selectItem itemValue="D" itemLabel="FAIL-DLI Standard" />
      <f:selectItem itemValue="F" itemLabel="FAIL-Special Standard" />
      <f:selectItem itemValue="G" itemLabel="FAIL-Physical" />
    </h:selectOneMenu>
    <br/>

    <br/>
    <b>2.Screen Protector has been applied: </b>
    <h:panelGroup id="dliSticker">
        <h:selectOneMenu value="#{qcFormBean.dlitcStickerValue}">
          <f:selectItem itemValue="P" itemLabel="Pass or Not applicable" />
          <f:selectItem itemValue="M" itemLabel="FAIL-Mechanical" />
          <f:selectItem itemValue="E" itemLabel="FAIL-Electrical" />
          <f:selectItem itemValue="C" itemLabel="FAIL-Cosmetic" />
          <f:selectItem itemValue="S" itemLabel="FAIL-Software" />
          <f:ajax event="change" execute="@this" render="perfbyDlitcSticker" />
        </h:selectOneMenu>
    </h:panelGroup>

    <h:panelGroup id="perfbyDlitcSticker">
        <h:selectOneMenu value="#{qcFormBean.stickerFreq}"
        rendered="#{!qcFormBean.dliStickerValue eq  'P'}">
            <f:selectItem itemValue="A" itemLabel="Always" />                
            <f:selectItem itemValue="O" itemLabel="Often" />
            <f:selectItem itemValue="S" itemLabel="Seldom" />                
        </h:selectOneMenu>
    </h:panelGroup>


    <br/>
    </font>

    </h:form>

    </h:body>
    </html>

Here is the error code I get with this code:

/indexv2.xhtml 88 76 ClientBehaviorHolder, : javax.faces.component.UIViewRoot@13fcf10

: javax.faces.view.facelets.TagException -/indexv2.xhtml 88 76 ClientBehaviorHolder, : javax.faces.component.UIViewRoot@13fcf10

0
2

, 'f: ajax', "a4j: ajax" richfaces ' xhtml, . "- ". , richfaces, , , , .

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
      "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml"
          xmlns:h="http://xmlns.jcp.org/jsf/html"
          xmlns:f="http://java.sun.com/jsf/core" 
          xmlns:a4j="http://richfaces.org/a4j"   >

    <h:head>
    <title>QC-Form</title>
    <link href="./css/styles.css" 
          rel="stylesheet" type="text/css"/>
    </h:head>

    <f:view>

    <h:body>
    <h1 class="title">QC Form</h1>
    <br/> <br/>

      <font face="comic sans MS" size="2" color="#33CCFF">
      <p><b>Enter the information below: </b> </p>
      </font>

    <h:form>

     <font face="comic sans MS" size="2"> 

     <h:panelGroup id="initialInfo">

        <b>Your initials: </b>  
            <h:inputText value="#{qcFormBean.techNameValue}"/><br/>
        <br/>

        <b>Model #: </b>  
        <h:selectOneMenu value="#{qcFormBean.modelValue}">
          <f:selectItem itemValue="3600" itemLabel="3600" />
          <f:selectItem itemValue="7200" itemLabel="7200" />
          <f:selectItem itemValue="8300" itemLabel="8300" />
          <f:selectItem itemValue="8400" itemLabel="8400" />
          <f:selectItem itemValue="8500p" itemLabel="8500p" />
          <f:selectItem itemValue="8800" itemLabel="8800" />
          <f:selectItem itemValue="9000" itemLabel="9000" />
          <f:selectItem itemValue="9008" itemLabel="9008" />
          <f:selectItem itemValue="9200" itemLabel="9200" />
          <f:selectItem itemValue="9300" itemLabel="9300" />
        </h:selectOneMenu><br/>
         <br/>

        <b>Date : </b>
         <h:outputText  value="#{currentDate}"/>
        <br/> <br/>


        <b>Serial #: </b>  
            <h:inputText value="#{qcFormBean.serialValue}"/><br/>
        <br/>

        <b>Customer Name: </b>  
            <h:inputText value="#{qcFormBean.customerNameValue}"/><br/>
        <br/>

        <b>Special Instructions: </b>  
            <h:inputText value="#{qcFormBean.specialInstructionsValue}"/><br/>    

     </h:panelGroup>
    </font>

      <font face="comic sans MS" size="2" color="#33CCFF">
      <p><b>QC Process</b> </p>
      </font>

     <font face="comic sans MS" size="2"> 

    <h:panelGroup id="dliSerial">
     <b>1.Unit Serial number has been applied: </b>
     <h:selectOneMenu value="#{qcFormBean.unitSerialValue}">
    <f:selectItems value="#{qcFormBean.valueQcValue}"/>
    </h:selectOneMenu>
    <br/>

    </h:panelGroup>

    <br/>
    <b>2.Screen Protector has been applied: </b>
    <h:panelGroup id="dliSticker">
        <h:selectOneMenu value="#{qcFormBean.dliStickerValue}">
          <f:selectItem itemValue="P" itemLabel="Pass or Not applicable" />
          <f:selectItem itemValue="M" itemLabel="FAIL-Mechanical" />
          <f:selectItem itemValue="E" itemLabel="FAIL-Electrical" />
          <f:selectItem itemValue="C" itemLabel="FAIL-Cosmetic" />
          <f:selectItem itemValue="S" itemLabel="FAIL-Software" />
          <a4j:ajax event="change" execute="@this" render="perfbyDliSticker"  limitRender="true" />
        </h:selectOneMenu>
    </h:panelGroup>

    <h:panelGroup id="perfbyDlitcSticker">
        <h:selectOneMenu value="#{qcFormBean.stickerFreq}"
        rendered="#{!qcFormBean.dliStickerValue eq  'P'}">
            <f:selectItem itemValue="A" itemLabel="Always" />                
            <f:selectItem itemValue="O" itemLabel="Often" />
            <f:selectItem itemValue="S" itemLabel="Seldom" />                
        </h:selectOneMenu>
    </h:panelGroup>


    <br/>
    </font>



    </h:form>

    </h:body>
    </f:view>
    </html>
0

f:ajax h:selectOneMenu. h:form ClientBehaviourHolder, f:ajax. h:selectOneMenu.


EDIT: f:ajax , , panelGroup selectOneMenu es:
<h:selectOneMenu value="#{qcFormBean.dlitcStickerValue}">
    <f:selectItem itemValue="P" itemLabel="Pass or Not applicable" />
    <f:selectItem itemValue="M" itemLabel="FAIL-Mechanical" />
    <f:selectItem itemValue="E" itemLabel="FAIL-Electrical" />
    <f:selectItem itemValue="C" itemLabel="FAIL-Cosmetic" />
    <f:selectItem itemValue="S" itemLabel="FAIL-Software" />
    <f:ajax event="change" execute="@this" render="perfbyDlitcSticker" />
</h:selectOneMenu>


EDIT2: </b> <br/> commandButton :
<h:panelGroup id="dliSticker">
    <h:selectOneMenu value="#{qcFormBean.dlitcStickerValue}">
      <f:selectItem itemValue="P" itemLabel="Pass or Not applicable" />
      <f:selectItem itemValue="M" itemLabel="FAIL-Mechanical" />
      <f:selectItem itemValue="E" itemLabel="FAIL-Electrical" />
      <f:selectItem itemValue="C" itemLabel="FAIL-Cosmetic" />
      <f:selectItem itemValue="S" itemLabel="FAIL-Software" />
      <f:ajax event="change" execute="@this" render="perfbyDlitcSticker" />
    </h:selectOneMenu>
</h:panelGroup>

<h:panelGroup id="perfbyDlitcSticker">
    <h:selectOneMenu value="#{qcFormBean.stickerFreq}"
    rendered="#{!qcFormBean.dliStickerValue eq  'P'}">
        <f:selectItem itemValue="A" itemLabel="Always" />                
        <f:selectItem itemValue="O" itemLabel="Often" />
        <f:selectItem itemValue="S" itemLabel="Seldom" />                
    </h:selectOneMenu>
</h:panelGroup>
+1

Source: https://habr.com/ru/post/1525492/


All Articles