Still celebrating National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17


JSF - Auto Tab To Next Field

Posted on 2008-10-02
Medium Priority
Last Modified: 2013-11-24

How can I implement jumping to next field after user enters all the required number of characters?
The document.getElementById('FieldId') ALWAYS returns null!!.

I have code like this

<h:inputtext id "FieldText"  maxlenght = "5" ....... onkeyup ="AutoTabToNextField(this, 'NextField')" />
h:inputtext id = "NextField" ,,,, />

My javascript looks like:

AutoTabToNextField(F1, F2)
  // This is the problem. No Matter what method I use to pass reference to F2,
 //  F2 is ALWAYS ALWAYS NULL or is not an OBJECT!!!

// F1 is passed correctly ... ALWAYS .. I think it is because of using "this"

  if (F1.value.length == F1.maxLength)


<<< Ali >>>
Question by:MohammadAliQureshi
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 2
  • 2
LVL 14

Assisted Solution

by:Farzad Akbarnejad
Farzad Akbarnejad earned 2000 total points
ID: 22631127
Instead of 'NextField' pass '[Form Name].NextField' (replace [Form Name] with name of form contains input control.


Accepted Solution

MohammadAliQureshi earned 0 total points
ID: 22632376
Hello FarzadA:

I think I have tried that as well and it did not work. However, let me try one more time. I will update you with the results.


<<< Ali >>>

Author Comment

ID: 22634440

I found the solution. I had to call my JS function with refernce to nextField as 'formID:FieldID'. Yes it is colon. The way I figured it out was to look at the HTML source created by the JSP and look at what are the ids for different fields. Then, within the function, I get the reference to the field by using document.getElementById to set the focus.

Since FarzadA started my thinking process which led me to a solution, I will award him full points. Thanks for your help FarzadA.


<<< Ali >>>
LVL 14

Expert Comment

by:Farzad Akbarnejad
ID: 22639273
'formID:FieldID' is JSF naming. You can use forceId=true attribute in inputText tag to force JSF use you id.

<h:inputtext id="NextField" forceId="true" ....

Now you can use its id without pointing to 'formID:'


Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

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.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

I had a project requirement for a displaying a user workbench .This workbench would consist multiple data grids .In each grid the user will be able to see a large number of data. These data grids should allow the user to 1. Sort 2. Export the …
Introduction This article is the first of three articles that explain why and how the Experts Exchange QA Team does test automation for our web site. This article explains our test automation goals. Then rationale is given for the tools we use to a…
The viewer will learn how to implement Singleton Design Pattern in Java.
This tutorial covers a practical example of lazy loading technique and early loading technique in a Singleton Design Pattern.
Suggested Courses

715 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question