Использование валидаторов, чтобы убедиться, что пользователь заполнил одно из двух обязательных полей - PullRequest
5 голосов
/ 31 января 2010

У меня есть форма ASP.NET для запросов на обмен валюты. Там есть два текстовых поля: количество-источник и количество-цель.

Один из них должен быть заполнен и только один.

Как реализовать это с помощью валидаторов, если применимо?

Ответы [ 2 ]

13 голосов
/ 31 января 2010

Для этого вы можете использовать пользовательские валидаторы:

<asp:Textbox id="textbox1" runat="server" />
<asp:CustomValidator id="valCustom" runat="server"
    ControlToValidate="textbox1"
    ClientValidationFunction="ClientValidate"
    OnServerValidate="ServerValidate"
    ErrorMessage="*You can only enter 1" display="dynamic">*
</asp:CustomValidator>

<asp:Textbox id="textbox2" runat="server" />
<asp:CustomValidator id="valCustom2" runat="server"
    ControlToValidate="textbox2"
    ClientValidationFunction="ClientValidate"
    OnServerValidate="ServerValidate"
    ErrorMessage="*You can only enter 1" display="dynamic">*
</asp:CustomValidator>

<script language="Javascript">
  function ClientValidate(source, arguments)
  {
    var tb1 = document.getElementById("<%=textbox1.ClientID %>").value;
    var tb2 = document.getElementById("<%=textbox2.ClientID %>").value;
    if (tb1 && tb2 || (!tb1 && !tb2)){
        arguments.IsValid = false;
    } else {
        arguments.IsValid = true;
    }
  }
</script>

на стороне сервера:

protected void ServerValidate(object sender, ServerValidateEventArgs args)
{
  if(string.isNullOrEmpty(textbox1.Text) && string.isNullOrEmpty(textbox2.Text))
    args.IsValid = false;
  else if(!string.isNullOrEmpty(textbox1.Text) && !string.isNullOrEmpty(textbox2.Text))
    args.IsValid = false;
  else
    args.IsValid = true;
}

Если вы используете jQuery, прокомментируйте ... это может быть намного чище.

1 голос
/ 31 января 2010

Я бы реализовал собственный Validator и украсил бы им оба текстовых поля. Если оба заполнены, то оба находятся в состоянии ошибки.

...