style.display = 'none' makes the error msg not display again

I have a clear button and onClientClick, I call a javascript function. This is what's happening

1. I click the submit button and an error msg is displayed because the textbox is empty
2. I click Clear and the Javascript is called and the error msg is cleared
3. So far so good
5. I click Submit again, and the textbox is empty but this time, the error msg is not displayed.

I think it's because of style.display = 'none' that wont allow the error msg to be displayed again.

Anything else i can use besides style.display ='none'?

<script type="text/javascript">
      function clrCtrl() {

          document.getElementById("<%= ccNumber.ClientID %>").value = "";
          document.getElementById("<%= RequiredFieldValidator4.ClientID %>").style.display = 'none';


Open in new window

Who is Participating?
Tom BeckConnect With a Mentor Commented:
This question sounds like a question I answered a while ago:

You have to use visibility:hidden instead of display:none to hide the error message on RequiredFieldValidators without disabling them.
Dave BaldwinFixer of ProblemsCommented:
'inline' and 'block' are the other two options.  You don't have to use that line at all, you can just leave the display setting alone.  What is it supposed to be doing for you?
CamilliaAuthor Commented:
>>What is it supposed to be doing for you?
style.display = 'none'  clears the erorr msg is the first time. This is good.

in Step 5 above, when I click on submit button again when the textfield is empty...the error msg should show again but it doesnt. I think it's because the first = 'none'
does something and the error msg is not displayed again...

I cant use "block'...i wasnt to clear the field but i dont want to clear it forever...
Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Dave BaldwinFixer of ProblemsCommented:
'block' is for things like <p> and <div> and 'inline' is for text and <span>.  Has nothing to do with clearing the field, only with how it is displayed.
CamilliaAuthor Commented:
No, let me rephrase my question This is the literal I have

And an input field:

<input type="text" maxlength="16"   class="InputFields"  tabindex="1" runat="server" name="ccNumber" id="ccNumber" />

<asp:RequiredFieldValidator runat="server" ID="RequiredFieldValidator4" ControlToValidate="ccNumber" Text="Card Number is required." ErrorMessage="Card Number is required."></asp:RequiredFieldValidator>

Open in new window

And the button that calls the Javascript and the submit button

 <asp:LinkButton ID="btnCancel" CausesValidation="false"  OnClientClick="clrCtrl();return false;" runat="server" Text="Clear"  />

<asp:LinkButton ID="lbSubmit"  OnClick="lbSubmit_OnClick" CausesValidation="true"   runat="server" Text="Submit"   />

Open in new window

1. The first time when I click on the submit button without entering anything in the input box, the fieldvalidator error msg is displayed.

2. I click the clear button and this error is  cleared

3. I click the submit button again without entering anything in the input box (just like step 1), but this time, the fieldvalidator doesnt display the error msg. I think it's because of the style.display ='none' does something to that field. If I remove the javascript...the fieldvalidator's error msg gets displayed the second time (or whenever i click submit without entering anything in the input box)
Dave BaldwinConnect With a Mentor Fixer of ProblemsCommented:
style.display ='none' makes it not display.  It's as simple as that.  'none' means no display.  If you want it to display after doing that, you have to make it either style.display ='inline' or style.display ='block'.
CamilliaAuthor Commented:
do I need if-else in the javascript to display and hide?? i dont think so. For example:
User clicks submit and the error msg is displayed. User clicks clear and the error msg is cleared. User clicks submit this point..the error msg should display again can I change that Javascript to display the error msg? I have to check the value of the input box?
Dave BaldwinFixer of ProblemsCommented:
If you are going to call "clrCtrl()" both times then you do need the if-else and a variable to keep track of the state.  Otherwise, it can be two different functions.
COBOLdinosaurConnect With a Mentor Commented:
A better way to do is to uses classes. If you have two classes in the css:

.showmsg {display:inline;}
.hidemsg {display:none;}
Then all you need to do in the script is a toggle:

document.getElementById("<%= ccNumber.ClientID %>").className =
(document.getElementById("<%= ccNumber.ClientID %>").value = "")? 'showmsg' : 'hidemsg';

CamilliaAuthor Commented:
Tommy, yes..i think i had seen a solution like that i remember it. I'll try it. Thanks
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

All Courses

From novice to tech pro — start learning today.