无法禁用JSF SelectOneRadio按钮

时间:2011-08-08 08:14:16

标签: java javascript html jsf web-applications

我有两个单选按钮,由JSF中的Backed bean的两个实例变量支持{这是要求,不要与一个变量绑定。}。并且,如果选中一个,则应禁用其他一个。下面是我的代码,它有什么问题?为什么它不像我预期的那样工作。

适当的帮助表示赞赏。

    <h:graphicImage url="/images/orange_arrows.gif" />
       <h:outputLabel for="addBundle">
          <h:outputText value="Subscribe Bundle :" styleClass="item-name"/>
       </h:outputLabel>


    <h:selectOneRadio id="addBundle" value="#{accountAdjustmentBean.bundleAdded}" required="false"
                    onchange="enableSubmit( this.checked != bundleAdded );disableRadioButton('unsubscribe');">
                    <f:selectItem id="subscribe" itemValue="true"/>
       <h:message styleClass="errors" for="addBundle"/>
    </h:selectOneRadio>

    <h:panelGroup/>

    <h:graphicImage url="/images/orange_arrows.gif" />
       <h:outputLabel for="removeBundle">
          <h:outputText value="Unsubscribe Bundle" styleClass="item-name"/>
       </h:outputLabel>


    <h:selectOneRadio id="removeBundle" value="#{accountAdjustmentBean.bundleRemoved}" required="false"
                onchange="enableSubmit( this.checked != bundleRemoved );disableRadioButton('subscribe');">
            <f:selectItem id="unsubscribe" itemValue="true"/>
       <h:message styleClass="errors" for="removeBundle"/>
     </h:selectOneRadio>

<h:panelGrid columns="1" styleClass="adjustments-submit">
        <h:commandButton id="submitBtn" action="#{accountAdjustmentBean.addDataBundleAction}"
                     value="Submit"/>


<f:verbatim>
    <script  type="text/javascript">

        function enableSubmit( enable ) {
            document.getElementById('ccAcountStatus:submitBtn').disabled = !enable;
        }

        // Disable submit button on load (enable when account locked status changes)
        enableSubmit(false);

        function disableRadioButton(elementId)    {
            document.getElementById(elementId).disabled = true;
    }

        // save the account locked status at page load. used to detect if changed.
        var bundleadded = </f:verbatim><h:outputText value="#{accountAdjustmentBean.bundleAdded}"/><f:verbatim>

    </script>
</f:verbatim>

1 个答案:

答案 0 :(得分:1)

单选按钮没有相互连接。

您可以做的只是绑定一个并使用脚本取消选择另一个。在你的bean做同样的事情,当布尔a设置为true时,将b设置为false,反之亦然。