Perl in a Nutshell

Perl in a NutshellSearch this book
Previous: 10.1 HTML Tag GenerationChapter 10
The CGI.pm Module
Next: 10.3 Maintaining State
 

10.2 Importing Method Groups

The syntax for calling CGI methods can be unwieldy. However, you can import individual methods and then call the methods without explicit object calls. The "birthday" example shown earlier could be written even more simply as follows:

#!/usr/bin/perl

use CGI param,header,p;

$bday = param("birthday");
print header();
print p("Your birthday is $bday.");
By importing the param, header, and p methods into your namespace, you no longer have to use the new constructor (since it is called automatically now), and you don't need to specify a CGI object with every method call.

CGI.pm also lets you import groups of methods, which can make your programs much simpler and more elegant. For example, to import all form-creation methods and all CGI-handling methods:

use CGI qw/:form :cgi/;
The method groups supported by CGI.pm are:

:cgi

All CGI-handling methods

:cgi-lib

All methods supplied for backwards compatibility with cgi-lib

:form

All form-generation methods

:html

All HTML methods

:html2

All HTML 2.0 methods

:html3

All HTML 3.0 methods

:netscape

All methods generating Netscape extensions

:ssl

All SSL methods

:standard

All HTML 2.0, form-generation, and CGI methods

:all

All available methods

You can also define new methods for HTML tag generation by simply listing them on the import line and then letting CGI.pm make some educated guesses. For example:

use CGI shortcuts,smell;

print smell {type=>'garlic',
           intensity=>'strong'}, "Scratch here!";
This will cause the following tag to be generated:
<SMELL TYPE="garlic" INTENSITY="strong">Scratch here!</SMELL>


Previous: 10.1 HTML Tag GenerationPerl in a NutshellNext: 10.3 Maintaining State
10.1 HTML Tag GenerationBook Index10.3 Maintaining State