How can I rewrite the ErrorMessage for a CustomValidator control on the client?

前端 未结 9 1305
鱼传尺愫
鱼传尺愫 2020-12-11 05:45

I have a CustomValidator that is validating a telephone number for several different telephone numbering schemes. The client-side javascript looks like this:



        
相关标签:
9条回答
  • 2020-12-11 05:58

    Just remove all instances of Text and ErrorMessage in the custom validator tag definitions then use

    $(#id_of_custom_validation_control).text("custom error message");
    

    Then with this, you can use one custom validator control and handle multiple error conditions

    E.g

    if(error1){
      $(#id_of_custom_validation_control).text("custom error message1");
    }else $(#id_of_custom_validation_control).text("custom error message2");
    

    Hope this helps

    0 讨论(0)
  • 2020-12-11 05:59

    The best way to change the error message of a validator control with image is:

    sender.innerHTML = "YOUR HTML WITH ANYTHING COME HERE"
    
    0 讨论(0)
  • 2020-12-11 06:00

    To change the error message, do it like this:

    if (!args.IsValid) document.getElementById('<%= cstPhoneNumber.ClientID %>').errormessage = "* Not a NA Phone #";
    

    To change the text, do this:

    if (!args.IsValid) document.getElementById('<%= cstPhoneNumber.ClientID %>').innerHTML = "* Not a NA Phone #";
    

    cstPhoneNumber should be replaced by the name of your validation control.

    0 讨论(0)
  • 2020-12-11 06:02

    Try this...

    Use sender.textContext in the Javascript for the error message and setup your CustomValidator as such:

    <asp:CustomValidator ID="cvdPhoneNumber" runat="server" Display="Dynamic" ForeColor="Red" ControlToValidate="txtPhoneNumber" ClientValidationFunction="validatePhoneNumber" ErrorMessage=""  />
    
    0 讨论(0)
  • 2020-12-11 06:03

    It looks like your using jquery so you could set the error message like this:

    $(sender).text("* Not a NA Phone #");
    

    Edit:

    Sorry for the delay but I was away on vacation.

    I was playing a round with a simple page and I think I understand how this works.

    When you set the errormessage on the sender in the client side validation function you are setting the equivalent of the ErrorMessage property. This is different from the Text property. The ErrorMessage sets the text displayed in the Validation summary, while the Text property is the text displayed in the validator control. Note that if you only set the ErrorMessage property (on the server) then the ErrorMessage will be copied into the Text property.

    What this means is that when you set sender.errormessage your actually setting the text that is displayed in the validation summary.

    Hopefully this will help clear it up. However, I still haven't seen a way to change the Text property from the client side validation function. I am also not sure why your sender object is not the validator object.

    0 讨论(0)
  • 2020-12-11 06:09

    sender.innerText = "Your message" will work.

    0 讨论(0)
提交回复
热议问题