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

24,702

Solution 1

function dateofbirth(sender, args) {

    var dtcDOB = document.getElementById('<%= dtcDOB.ClientID %>');

    var dob = new Date(dtcDOB.value);
    var currDate = new Date();

    if (dtcDOB.value == "") {
        args.IsValid = false;
        sender.textContent = "Provide DOB.";
        return;
    }

    args.IsValid = true;
}

Try sender.textContent = "your err msg". It worked for me.

Solution 2

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.

Solution 3

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

sender.innerHTML = "YOUR HTML WITH ANYTHING COME HERE"

Solution 4

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.

Solution 5

sender.innerText = "Your message" will work.

Share:
24,702
Dustman
Author by

Dustman

A long time ago, in a galaxy far, far away, I was a Web dev for an outfit in Bellvue, WA. Now, I kind of do a bit of this and that with the odd bit of computer-related work on the side.

Updated on October 07, 2020

Comments

  • Dustman
    Dustman over 3 years

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

    validatePhoneNumber(sender, args) {
        cleanNumber = args.Value.replace(/\D/, "");
        country = $("#" + CountryID).get(0).value;
        switch (country) {
            case "North America":
                args.IsValid = validateNAPhoneNumber(cleanNumber);
                if (!args.IsValid) sender.errormessage = "* Not a NA Phone #";
                break;
            case "UK":
                args.IsValid = validateUKPhoneNumber(cleanumber);
                if (!args.IsValid) sender.errormessage = "* Not a UK Phone #";
                break;
    ...
        }
    }
    

    The actual validation takes place properly, and the CustomValidator has the correct IsValid property at all times. The sender.errormessage, however, seems to be rewritten just after this function call to it's default value. How can I change the errormessage value, and make it "stick"?

  • drs9222
    drs9222 almost 15 years
    Doesn't document.getElementById(sender.id) equal sender?
  • Dustman
    Dustman almost 15 years
    That is actually how I started out doing this, and that didn't work either. As it happens, the js sender.errormessage member does have the same content as the CustomValidator.ErrorMessage when the page first loads, but altering that content does not alter the displayed message.
  • Dustman
    Dustman almost 15 years
    Tried that, but no. Digging around, I find that the sender is not the span element, but is instead some other DOM object that doesn't display anything. Thanks, though.
  • drs9222
    drs9222 almost 15 years
    That's odd when I tried this at home the sender was the span. How was the sender object related to the span? You may be able to access the span from the sender. If not do you have a way to get the id of the span in your script? If so you could still do this. Sorry I can't be more helpful at the moment as I am at work.
  • Dustman
    Dustman almost 15 years
    A number of websites state that the "sender.errormessage" construct is the way to do this, so I suspect that I have done something wrong in the grander scheme of things that is preventing any of these methods from working. I guess I'll have to code up a test page and see if a simpler version doesn't act the way everyone seems to expect.
  • mbomb007
    mbomb007 over 7 years
    Note that if the error message is dynamic then HTML could be injected. Use textContent if you don't want HTML to be rendered.