Chapter 2: Forms

This chapter explains what forms are.

2.1 Overview

Forms are the user interface to your application. The simplest form has some controls (like entry fields, radio buttons and check boxes), and a pushbutton to submit the form. When the form is submitted, it makes a request to the Web server to start a server-side program, bundles up the data entered onto the form, and sends it to the server.

You can also design more complex forms, where the controls can interact with each other while the end-user is entering data. For example, you might disable certain fields unless a particular radio button is selected. For this type of form you need to learn some JavaScript or JScript, which are scripting languages for HTML Web pages. For an overview of JavaScript, Jscript and event handlers see the section Form Programming in the chapter Overview of Internet Programming.

2.2 Controls and Data

Each control on a form has a name and a value. When the end-user submits the form, the information on the form is sent to the server-side program as a set of name/value pairs. Extensions to COBOL syntax enable you to associate the names of the controls on the form directly with COBOL data items in your server-side program. When the data in the form is posted to the server-side program, the data items are set to the values of the controls on the form. The way you do this is covered in the chapter Server-side Programming.

2.3 Submitting Form Data to the Server

Once the end-user has entered data on a form, the data must be sent to a Web server, and a server-side program run to process the data. This is known as submitting the form. An input form has an Action property, which determines the URL of the server-side program to run when the form is submitted.

2.3.1 Submit Mechanism for HTML Forms

The Submit control on a form starts a server-side program, posting it the data which has been entered on the form. The Submit control is usually a pushbutton, but it can also be an image. The Submit control starts the program whose URL is set up on the form's Action. In effect the Action property determines which program is run when the form is submitted.

You can optionally also have a Reset control, which resets the contents of all the controls to their default values. The Reset control is also usually a pushbutton.

2.4 Creating Forms

Extensions to the Object COBOL syntax provided with Server Express enable you to create forms in two ways:

For example, the following web page:

would require the following HTML:

<HTML>
 <HEAD>
  <TITLE>Blank</TITLE>
 </HEAD>

 <BODY>
  <H1>Sample Form</H1>
  <P>Please enter the following details:</P>
  
  <FORM METHOD="POST" 
        ACTION="/cgi-bin/cobrun/userid/program">
   
   <P>Name:&nbsp;&nbsp;&nbsp;&nbsp;<INPUT TYPE="TEXT" NAME="name"></P>
   <P>Email id:&nbsp;<INPUT TYPE="TEXT" NAME="emailid"></P>
   <P>Phone:&nbsp;&nbsp;&nbsp;<INPUT TYPE="TEXT" NAME="phone"></P>

   <P><INPUT TYPE="SUBMIT" NAME="Submit1">&nbsp;&nbsp;
      <INPUT TYPE="RESET" NAME="Reset1"></P>
  
  </FORM>
 </BODY>
</HTML>

The tags <HTML></HTML> identify the text between them as HTML. The tags <HEAD></HEAD> enclose optional header information. You put the mark-up tags that create the text and other page elements between the <BODY></BODY> tags.

The <H1></H1> tag creates a first level heading. The <P></P> tag creates a paragraph.

&nbsp; is an entity. It specifies a no-break space. There are other entities that enable you to enter other characters into an HTML document; for example, &gt; enables you to enter a greater-than symbol into your document; you cannot enter this symbol directly as it is used by HTML to delimit a tag.

The <FORM></FORM> tag creates the input form elements. Form objects (text boxes, check boxes, radio buttons, submit buttons) are represented by INPUT elements. The TYPE attribute determines what type of object to display. For example, the value TEXT (which is the default), generates a text box. The SUBMIT and RESET values create the equivalent buttons. The ACTION element defines what happens when the user presses the SUBMIT button; in this case, using cobrun to trigger the program program. The POST element determines that the data entered into the text boxes is sent when the user presses the SUBMIT button. See the chapter Server-side Programming for details on how to accept data from and return data to the browser.

There are many books available which describe how to create HTML pages and forms. The HTML tags are also described on the Web site of the World Wide Web Consortium.


Copyright © 2002 Micro Focus International Limited. All rights reserved.
This document and the proprietary marks and names used herein are protected by international law.