LanguagesJavaScriptSo You Want Interactive Form Elements, Huh?

So You Want Interactive Form Elements, Huh? content and product recommendations are editorially independent. We may make money when you click on links to our partners. Learn More.

Use these to jump around or read it all…

[The Full Code]
[The Form Elements]
[Getting the First Focus]
[From Box One to Box Two]
[Submitting onFocus]

     This has been a tutorial that’s been sitting in my “working” directory for quite some time. My “working” file is place where I have little blips of code that could, at sometime or another, become a tutorial. Most of the pieces of code don’t work. That’s why they’re in a working directory.

     This concept always seemed like something that I could do, but I could never quite get it until I posted the code to the HTML Goodies Discussion groups. Thanks to Jim Young for helping. He reposted a code he created for a client that got the same effect I’ll show you here. I didn’t use his full code, just the one missing piece that I needed. Thank you Jim – you’re a gentleman.

The Effect

     I am often asked how to set up a form so that after the user fills in a pre-determined number of characters, the cursor jumps to the next form element all by itself.

     Please understand that this only works with browsers version 4.0 and above. I’ll tell you why in a moment. But don’t let that stop you from installing this on your forms. Lower version browsers will not understand the Event Handler command and will not trigger the functions. That means no errors. Those that have browsers version 4.0 or higher get the effect, those who don’t just fill in the form as they normally would.

     Here’s an example with four text boxes:

Put in Four Characters:
And Again:                    
And Again:                    
And Again:                    

(don’t click – it won’t work)

The Full Code

     Here’s where I often catch heck from experienced programmers. Much of the code I offer on HTML Goodies is wordy. Before you write to tell me, yes, I know this can be done with a single function. In fact, Jim’s code was a single function. The code I am offering here breaks out each function individually.

     I only do that because it makes the code simpler and allows a less-experienced programmer to grasp the concept. That’s all…

     OK! Let’s look at the full source code for the effect. I have it here in text format. The bold text tells what each section does. You can copy and paste it straight away if you’d like. I have commented out the descriptive text.

Here’s the Code

     The overall concept is this: There are four form elements, five if you count the submit button. A small piece of JavaScript places focus (the cursor) on the first form element.

     Four JavaScript functions were created, each is assigned to a text box. The JavaScript functions look at the number of characters within the text box. When the number reaches four, focus (again, the cursor) is placed upon the next text box.

     Each function can be changed around to your heart’s content allowing as many or as few letters as you’d like.

     BTW – I tried this with other form elements (radio buttons, check boxes, Select boxes). The effect works. The form element becomes highlighted, but that’s it. The user then has to use their mouse to complete the task. That’s not at all a bad thing, I just wanted to make you aware of it.

     BTW again – I also tried to have the last form element jump to the submit button to automatically submit the form. No dice. There is a method of doing it without using a submit button and I’ll quickly tell you how it’s done at the end of the tutorial.

     Now let’s break this puppy down. We’ll start with the form elements.

The Form Elements

<FORM NAME=”joe”>
<INPUT TYPE=”text” name=”burns” size=”10″ onKeyUp=”check()”><BR>
<INPUT TYPE=”text” name=”tammy” size=”10″ onKeyUp=”check2()”><BR>
<INPUT TYPE=”text” name=”chloe” size=”10″ onKeyUp=”check3()”><BR>
<INPUT TYPE=”text” name=”mardi” size=”10″ onKeyUp=”check4()”><BR>
<INPUT TYPE=”submit” VALUE=”Click to Send” NAME=”go”>

     This is a basic form. The name of the form is “joe”.

     After that, four text boxes. Each box is given a name, a size, a maximum length, and is finally attached to a function triggered to work using the onKeyUp Event Handler.

     This is why the script only works in version 4.0 or better browsers. That onKeyUp Event Handler is a relatively new command. This is where I ran into nothing but trouble. You see, the script must be set up so that every time someone enters a new character into a text box, the function must run in order to recount the number of characters the user has entered.

     I tried everything – I mean everything. I went with onFocus, onClick, I tried setting the function to a “for” loop and a “while” loop. I set up a setTimeout() function. Nothing worked. As soon as I put in the onKeyUp, success. Each time a key is released, the function runs.

     So easy, yet so hard to find.

     Now that we know the names of all of the form elements, we can start to build some JavaScript hierarchy statements. For example, the first text box can be called upon through the statement document.joe.burns.

     Furthermore, the number of characters within the first text box can be returned through the hierarchy statement document.joe.burns.value.

     With those two concepts, the scripts basically build themselves.

Getting the First Focus

     You may have noticed that when you arrived at this page, the first text box already had the cursor blinking away. That didn’t just happen by default. I needed to “force” focus to the first text box. I did it in the BODY flag like so:

<BODY BGCOLOR=”ffffff” onLoad=”document.joe.burns.focus()”>

     It’s that focus() that does the trick. By attaching it to the end of a hierarchy statement, it puts focus upon the form element. In this case, the first text box (burns) under the form (joe).

     Keep that concept in mind, we’ll do it again and again throughout the four functions.

From Box One to Box Two

     The first two text boxes are named “burns” and “tammy”. You just learned that if you then attach focus() to the end of the hierarchy statement, you can set focus upon the form element. Let’ put those two concepts to work.

     The text box “burns” has its onKeyUp Event Handler set to a function named check(). It looks like this:

function check()
var letters = document.joe.burns.value.length +1;
if (letters <= 4)

     The function first sets the number of characters found within the first textbox (burns) to a variable and then adds one. The onKeyUp Event Handler is the trick. It forces the function to run every time something is entered.

     Next, an If statement asks if the number characters within the text box “burns” is less-than or equal to four. If so, then focus remains upon the textbox “burns”.

     We want the effect to allow four letters to appear in the text box. To get that effect, we add one to the number of characters found in the box. That way, one equals two, two equals three, etc., etc. Once you put in the fourth letter, the If statement is no longer true. Yes, you could get the same effect by not adding one and setting all the numbers up one, but that gets confusing. By adding one, you can set the If statement to the number of letters you want to appear in the box. It’s much easier to follow.

     Once the If statement is no longer true (“letters” now equals five but only four letters are in the box), focus jumps to the next box, “tammy”.

     Now that focus is upon “tammy”, the function check2() is not the one that runs each time a key is let up. See that in the form elements? The textbox “tammy” has onKeyUp set to check2().

     The function looks like this:

function check2()
var letters2 = document.joe.tammy.value.length +1;
if (letters2 <= 4)

     Does it look familiar? It should. It’s the exact same format as before except for:

  • The function name has changed from check() to check2()
  • The variable name letters has been changed to letters2
  • The hierarchy statements are now set to jump from textbox 2 to 3.

     The reason for the changes is that you cannot have the same variable names used twice to represent two different values within the same script.

     Once focus is upon textbox three, “chloe”, the function check3() takes over and performs the same tasks.

     Once focus is upon the fourth textbox, “mardi”, the function check4() takes over and does the same thing, except this time when four letters are entered, focus will jump to the submit button.

     Don’t expect the submit button to do anything. It won’t.

Got it?

     Do you see how the functions work? Each is doing the exact same thing. You just have to change out some variable names so that you won’t get JavaScript errors.

     Now, what about getting the form to submit when the user finishes the last box?

Submitting onFocus

     Right up front, let me tell you a couple of drawbacks to using this:

  • If the user doesn’t fill out the form in order, this might submit an unfinished form.
  • The effect STINKS if you use a simple mailto: to submit your form. It’s not so bad if you submit to a CGI.

     Step One: Add an ACTION=”–” attribute to your main FORM flag. Like so:

<FORM NAME=”joe” ACTION=”/Goodies/cgi-bin/”>

     Step Two: Lose the submit button altogether.

     Step Three: in the final function, set the final focus to:


     That will trigger the form to submit just as if you clicked the submit button. Again, if you’re using a simple mailto: format, there are only about 100 things that can go wrong. It may not be too bad if you’re attaching your form to a CGI.

That’s That

     This is a great effect that will help your viewers along when filling out your form elements. Remember that you can set the functions to look for any number of characters. Just be sure to set the numbers correctly.




[The Full Code]
[The Form Elements]
[Getting the First Focus]
[From Box One to Box Two]
[Submitting onFocus]

Get the Free Newsletter!

Subscribe to Developer Insider for top news, trends & analysis

Latest Posts

Related Stories