HTML Markup | JavaScript | Java | Computer Sci | Home & Links

Tutorial 9 - Working With Forms

User interaction is commonly accomplished through the use of HTML forms and their control objects. Interaction involves acquiring data and then performing some task based on that information. The results can be presented either with dialogs or more commonly by using other control objects.

As this tutorial relies heavily on their use, you should already be able to create an HTML form and include controls in a functional layout. Refer to my Creating Forms and Quick Forms pages for details.

Accessing Form and Control Objects

Forms can be designed to permit controlled (ie. prevalidated) data such as radio buttons, check boxes and select lists or free format data such as text entry boxes and file uploads using controls. These forms can be validated before submission. The controls can also be used for input and output in client-side utilities that are never submitted to an external server. Note that there are two techniques for referencing a control object when reading or modifying.

The DOM level 1 element access method (new way) requires NO form element and uses the format:

document.getElementById('control_id')

Use the element method [PREFERRED WAY] when:

Note: Removal of the form element helps suppress false submissions in some browsers. See the validation by entry topic for an alternate technique.

The DOM level 0 form access method (old way) requires a surrounding form element and uses these formats:

document.form_name.control_name
document.forms['fname'].elements['ename']
document.forms[fidx].elements[eidx]

Use the form method (old way) when any of the following conditions apply:

Note: Gecko engine based browsers (eg FireFox) do not treat form objects in the same manner as MSIE and Opera. To them, forms are not globally accessible so either they are passed to the called function as an object or the specific value is passed. MSIE can access a form by using its specific name in the function. If you always pass the form through as a function parameter your routines will work in both sets of browsers! And it is better programming practice too!

Accessing Control Contents

Most controls can have their contents accessed or updated through the value property of the control's object. When used on the right side of an (equal's) assignment, the current value of the object is read. When used on the left side of an assignment, the object is updated. Exceptions to this general rule are:

Note: Although radio buttons are the most commonly indexed input control, any control can be set up for indexing by reusing (overloading) its name attribute in HTML. One appropriate use would be for gathering a column of numbers (perhaps scores or unit prices) in an array within a loop and doing totals or averages. The arrays always start at '0' and are accessed similar to the radio control example above.

Simple Text Control

Text input (single line) and textarea (multiple line) controls are commonly used to both input and output freeform data. The simplest cases are explained in my QuickForms tutorial. The following example places the results of the system object Date method toString() into an input area. The input box is made readonly to prevent typing to it.

Since this is a simple action it can be done within the event call itself such as:

<button onclick="now=new Date();document.getElementById('t').value=now.toString();">
Display date &amp; time</button>
<input id="t" class="box300" type="text" readonly="readonly"/>

However a more structured and easier to read approach is to separate the programming action into its own function that can be removed to the head section of the document (or even to a separate file). The activating event passes one control object to the called function so that it can be updated.

Toggle Buttons

Some utilities use a toggle or push to start/push to stop button. One example is a run/pause button within a slide show. It is easy to alter a button's caption using its value property but only if you use an input type="button" element rather than a button element. Use arrays for the off caption, on caption and state as well as a switch construct to control the action statements for the set of buttons. Note that an onload="toggleInit()"; is required for initialization and styling.

Example: Radio Button Confirmation

There are times when you may need to confirm that something has been read or an agreement made before access is given to a page. This can be done easily with a radio button control. Even more design elements (legend and fieldset) are included in this example. Note their effect.

Licence Agreement

Here is the button setup and event call. For the complete form read the source file.

<label for="y">I have read and accept this agreement</label>
<input id="y" name="rbc" type="radio"/>
<label for="y">Yes</label>
<input id="n" name="rbc" type="radio" checked="checked"/>
<label for="n">No</label>
<button onclick="doYes(document.getElementById('y').checked);">
View Sitemap</button>

And here is the JavaScript function. The === is important!

Note: In this example I chose to pass only a simple data value rather than a control or complete form. It was sufficient for performing a test. However if feedback to a form control is needed, then the form or at least the control must be passed. Some programmers choose to always pass the form for consistency.

If you want this agreement to be remembered so that it doesn't have to be repeated, you will need to bake a cookie as described in the Cookies tutorial. If you need to log that an agreement was made, you will need to do a mailto submission as outlined in the Quick Forms tutorial. If you need security (ie. a concealed jump address), try FlashPeak's CryptHTML or invisitec.com.



JR's HomePage | Comments [jstutor9.htm:2010 02 03]