Pergunta

Eu pensei que o que eu estava tentando fazer era bastante trivial, mas acabou me incomodando significativamente. Aqui está a situação.

Eu tenho dois botões de rádio (implementados usando o Radbutton) e um RadTextBox. Quero verificar o cliente antes de enviar o formulário de que o RadTextBox não está vazio quando o dos dois botões de rádio é selecionado (digamos o primeiro). Eu usei o CustomValidator e defini ValidateEmptyText = "true" sem sorte. O extrato do código está abaixo:

<asp:Panel runat="server" ID="Panel1">
<table>
    <tr>
        <td class="auto-style5">
            <telerik:RadButton ID="rdBtnIndividual" runat="server" AutoPostBack="False" GroupName="rdEmplrType" 
                Text="Individual" ToggleType="Radio" OnClientCheckedChanged="rdBtnPhysical_CheckedChanged" 
                UseSubmitBehavior="False">
                <ToggleStates>
                    <telerik:RadButtonToggleState PrimaryIconCssClass="rbToggleRadioChecked" />
                    <telerik:RadButtonToggleState PrimaryIconCssClass="rbToggleRadio" />
                </ToggleStates>
            </telerik:RadButton>
        </td>
        <td>
            <telerik:RadButton ID="rdBtnLegal" runat="server" AutoPostBack="False" GroupName="rdEmplrType" Text="Legal Entity" 
                ToggleType="Radio" OnClientCheckedChanged="rdBtnLegal_CheckedChanged" UseSubmitBehavior="False">
                <ToggleStates>
                    <telerik:RadButtonToggleState PrimaryIconCssClass="rbToggleRadioChecked" />
                    <telerik:RadButtonToggleState PrimaryIconCssClass="rbToggleRadio" />
                </ToggleStates>
            </telerik:RadButton>
        </td>
    </tr>
    <tr>
        <td class="auto-style5">
            <label>Name:</label>
        </td>
        <td>
            <telerik:RadTextBox ID="txtName" Runat="server" EmptyMessage="Name" LabelWidth="64px" Resize="None" Width="160px" DisabledStyle-BackColor="Silver">
            </telerik:RadTextBox>
        </td>
        <td><asp:RequiredFieldValidator ID="THIS_IS_WORKING" ControlToValidate="txtName"
                runat="server" ErrorMessage="<img src='images/Exclamation.png' Title='Required Field'/>" >
            </asp:RequiredFieldValidator>
        </td>
    </tr>
    <tr>
        <td class="auto-style5">
            <label>Father's Name</label>
        </td>
        <td style="width:100px">
            <telerik:RadTextBox ID="txtFathersName" Runat="server" EmptyMessage="Father's Name" LabelWidth="64px" Resize="None" Width="160px" DisabledStyle-BackColor="Silver">
            </telerik:RadTextBox>
        </td>
        <td>
            <asp:CustomValidator runat="server" ID="NOT_WORKING_VALIDATOR" ControlToValidate="txtFathersName" ValidateEmptyText="True"
                ClientValidationFunction="RequiredIfIndividual"
                ErrorMessage="<img src='images/Exclamation.png' Title='Required Field'/>" EnableClientScript="True">
            </asp:CustomValidator>

        </td>
    </tr>
</table>
</asp:Panel>

O JavaScript está abaixo:

<script type="text/javascript">
    function RequiredIfIndividual(sender, args) {
        var chkBoxIndividual = $find("<%=rdBtnIndividual.ClientID%>");
        chkBoxIndividual = $telerik.toButton(chkBoxIndividual);
        if (chkBoxIndividual.get_checked()) {
            if (args.Value == "") {
                args.IsValid = false;
            }
            else {
                args.IsValid = true;
            }
        } else {
            args.IsValid = true;
        }
    }

</script>
Foi útil?

Solução

Depois de passar algum tempo para acertar esse problema, consegui encontrar a causa raiz do problema.

O problema está relacionado ao novo modo de validação discreto do .NET 4.5. Para que isso funcione corretamente, o JQuery 2.0 é necessário. Isso é padrão no .NET 4.5. No entanto, a versão jQuery incorporada em RadControls (até pelo menos a versão 2013q3) é v1.9.1 (ver aqui). Como resultado, o CustomValidator não funciona mais corretamente.

Existem duas alternativas para isso - eu só tentei o primeiro com sucesso:

  1. Desative o modo de validação discreto. Para fazer isso, você precisa incluir a seguinte linha no <appSettings> Seção do web.config Arquivo:

    <add key="ValidationSettings:UnobtrusiveValidationMode" value="None" />

    A desvantagem: o modo de validação discreto foi projetado para fazer com que os novos recursos HTML5, a fim de eliminar o código JavaScript gerado para realizar as validações, resultando em páginas mais leves (consulte aqui). Ao desativá -lo, você não está usando esse recurso.

  2. Escolha não usar a versão incorporada do jQuery para RadControls (ou seja, v1.9.1) e use o fornecido pelo .NET 4.5 (ou seja, v2.0).

    A desvantagem: o problema aqui é que os RadControls foram testados usando a versão incorporada do jQuery e você pode ter problemas. Para desativar a versão incorporada do jQuery, consulte esse link

Espero que isso ajude a próxima pessoa que tropeçará no mesmo problema.

Outras dicas

Você precisa chamar manualmente a função ValidatorValidate e passar na instância do validador personalizado dentro da RDBTNPHYSICAL_CHECKEDCHANGED e dos manipuladores RDBTNLEGAL_CHECKEDCHANGED. Eu preparei um pequeno exemplo para você abaixo:

  <script type="text/javascript">
            function RequiredIfIndividual(sender, args) {
                var chkBoxIndividual = $find("<%=rdBtnIndividual.ClientID%>");
                chkBoxIndividual = $telerik.toButton(chkBoxIndividual);
                if (chkBoxIndividual.get_checked()) {
                    if (args.Value == "") {
                        args.IsValid = false;
                    }
                    else {
                        args.IsValid = true;
                    }
                } else {
                    args.IsValid = true;
                }
            }

            function rdBtnPhysical_CheckedChanged(sender, args) {
                ValidatorValidate($get("NOT_WORKING_VALIDATOR"));
            }

            function rdBtnLegal_CheckedChanged(sender, args) {
                ValidatorValidate($get("NOT_WORKING_VALIDATOR"));
            }

        </script>

Acabei de testar o código e parece funcionar bem.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top