Chapter 4 A crash course in HTML Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 1 Objectives Applied Code the HTML for an HTML document using any of the tags and attributes presented in this chapter. Knowledge Describe the use of the Head, Title, and Body tags that are used for HTML documents. Describe the use of the Anchor (A), Table, Tr, Td, H1, H2, Br, and Image (Img) tags. Describe the use of a style sheet. Describe the use of text boxes, check boxes, radio buttons, combo boxes, list boxes, text areas, and Submit buttons. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 2 Objectives (cont.) Explain how an HTML form is used to pass control to a JSP or servlet. Describe tab order as it applies to HTML documents. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 3 An HTML page viewed in a browser Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 4 The HTML document for the page <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>Murach's Java Servlets and JSP</title> </head> <body> <h1>Email List applications</h1> <p>To run the following applications, click on the appropriate link:</p> </body> </html> Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 5 HTML basics HyperText Markup Language (HTML) is used to provide the user interface for web applications. To write and edit HTML code and JSPs, you can use a general text editor like NotePad, a text editor that’s specifically designed for working with HTML, or an Integrated Development Environment, or IDE, that’s designed for developing web applications. An HTML document is used to define each HTML page that’s displayed by a web browser. Within an HTML document, HTML tags define how the page will look when it is displayed. Each of these HTML tags is coded within a set of brackets (< >). HTML tags aren’t case sensitive. To make your code easier to read, you can use spaces, indentation, and blank lines. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 6 An HTML document that contains comments <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <!-- begin the Head section of the HTML document --> <head> <title>Murach's Java Servlets and JSP</title> </head> <!-- begin the Body section of the HTML document --> <body> <h1>Email List applications</h1> <p>To run the following applications, click on the appropriate link:</p> <!-<p>Links to come.</p> --> </body> </html> Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 7 Basic HTML tags Tag <!doctype ... > <html> </html> <head> </head> <title> </title> <body> </body> Murach’s Java Servlets/JSP (2nd Ed.), C4 Description Identifies the type of HTML document. This tag is often inserted automatically by the HTML editor. Marks the beginning and end of an HTML document. Marks the beginning and end of the Head section of the HTML document. Marks the title that is displayed in the title bar of the browser. Marks the beginning and end of the Body section of the HTML document. © 2008, Mike Murach & Associates, Inc. Slide 8 Basic HTML tags (cont.) Tag <h1> </h1> <h2> </h2> <p> </p> <br> <b> </b> <i> </i> <u> </u> <!-- --> Description Tells the browser to use the default format for a heading-1 paragraph. Tells the browser to use the default format for a heading-2 paragraph. Tells the browser to use the default format for a standard paragraph. Inserts a line break. Marks text as bold. Marks text as italic. Marks text as underlined. Defines a comment that is ignored by the browser. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 9 Two Anchor tags viewed in a browser Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 10 Anchor tags… With URLs that are relative to the current directory <a href="join.html">The Email List application 1</a><br> <a href="email/join.html"> The Email List application 2</a><br> With relative URLs that navigate up the directory structure <a href="../">Go back one directory level</a><br> <a href="../../">Go back two directory levels</a><br> With URLs that are relative to the webapps directory <a href="/">Go to the default root directory for the web server</a><br> <a href="/musicStore">Go to the root directory of the musicStore app</a> With absolute URLs <a href= "http://www.murach.com/email">An Internet address</a> <a href="http://64.71.179.86/email">An IP address</a> Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 11 The Anchor tag Tag <a> </a> Description Defines a link to another URL. When the user clicks on the text that’s displayed by the tag, the browser requests the page that is identified by the Href attribute of the tag. One attribute of the Anchor tag Attribute href Description Specifies the URL for the link. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 12 How to code attributes for tags Within the starting tag, code a space and the attribute name. Then, if the attribute requires a value, code the equals sign followed by the value between quotation marks with no intervening spaces. If more than one attribute is required, separate the attributes with spaces. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 13 How to code links to other HTML pages A tag can have one or more attributes, and most attributes require values. Although it’s considered a good coding practice to code values within quotation marks, the quotation marks aren’t required. When you code a relative URL in the Href attribute, the URL can be relative to the current directory, which is the one for the current HTML page, or the URL can be relative to the web server’s directory for web applications. When you code an absolute URL, you code the complete URL. To do that, you can code the name of the host or the IP address for the host. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 14 The HTML code for a table <p>Here is the information that you entered:</p> <table cellspacing="5" cellpadding="5" border="1"> <tr> <td align="right">First name:</td> <td>John</td> </tr> <tr> <td align="right">Last name:</td> <td>Smith</td> </tr> <tr> <td align="right">Email address:</td> <td>jsmith@hotmail.com</td> </tr> </table> Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 15 The table displayed in a browser The tags for working with tables Tag <table> </table> <tr> </tr> <td> </td> Murach’s Java Servlets/JSP (2nd Ed.), C4 Description Marks the start and end of the table. Marks the start and end of each row. Marks the start and end of each data cell within a row. © 2008, Mike Murach & Associates, Inc. Slide 16 How to code tables A table consists of rows and columns. The intersection of a row and column creates a cell that can hold data. It’s common to store other types of data besides text within a cell, such as images, links, or even another table. Attributes can be used with the Table, TR, and TD tags to control the formatting of the table. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 17 Attributes of the Table tag Attribute border cellspacing cellpadding width height Description Specifies the visual border of the table in pixels. To turn the border off, specify a value of 0. Specifies the number of pixels between cells. Specifies the number of pixels between the contents of a cell and the edge of the cell. Specifies the width of the table in pixels or as a percentage of the browser’s display space. Specifies the height of the table in pixels or as a percentage of the browser’s display space. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 18 Attributes of the TR tag Attribute valign Description Specifies the vertical alignment of the contents of the row. Acceptable values include Top, Bottom, and Middle. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 19 Attributes of the TD tag Attribute align colspan rowspan height width valign Description Specifies the horizontal alignment of the contents of the cell. Acceptable values include Left, Right, and Center. Specifies the number of columns that the cell will span. Specifies the number of rows that the cell will span. Specifies the height of the cell in pixels. Specifies the width of the cell in pixels. Specifies the vertical alignment of the contents of the row. Acceptable values include Top, Bottom, and Middle and will override any settings in the TR tag. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 20 HTML code that includes an image <p>Here is the image for the Murach logo:</p> <img src="images/murachlogo.jpg" width="100" height="100"> The HTML code displayed in a browser Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 21 The Image tag Tag <img> Description Specifies how to place a GIF or JPEG image within an HTML page. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 22 Common attributes of the Image tag Attribute src height width alt border hspace vspace Description Specifies the relative or absolute URL for the GIF or JPEG file. Specifies the height of the image in pixels. Specifies the width of the image in pixels. Specifies the text that’s displayed when the image can’t be displayed. Specifies the width of the border in pixels with 0 specifying no border at all. Specifies the horizontal space in pixels. This space is added to the left and right of the image. Specifies the vertical space in pixels. This space is added to the top and bottom of the image. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 23 Common attributes of the Image tag (cont.) Attribute align Description Specifies the alignment of the image on the page. Acceptable values include Left, Right, Top, Bottom, and Middle. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 24 Other image examples <img src="java.gif" width="175" height="243"> <img src="../../images/murachlogo.jpg" width="100" height="100"> <img src="http://www.murach.com/images/ murachlogo.jpg" width="100" height="100"> How to include images in an HTML page The two types of image formats that are supported by most web browsers are the Graphic Interchange Format (GIF) and the Joint Photographic Experts Group (JPEG). JPEG files, which have a JPEG or JPG extension, are typically used for photographs and scans, while GIF files are typically used for other types of images. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 25 The code for a style sheet body { font-family: Arial, sans-serif; font-size: 12px } a { text-decoration : underline } a:hover { text-decoration : underline; color : #CC0000 } h1 { font-size: 16px; color: #003366; vertical-align: top; margin-top: 10px; margin-bottom: 0px } h2 { font-size: 16px; color: #003366 } h3 { font-size: 14px; color: #003366 } The code in the HTML document that links to a style sheet <head> <title>Murach's Java Servlets and JSP</title> <link rel="stylesheet" href="styles/murach.css"> </head> Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 26 An HTML page after the style sheet has been applied to it Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 27 The Link tag Tag <link> Description Specifies the external style sheet. Attributes of the Link tag Attribute href rel Description Specifies the location of the style sheet. Specifies the type of link. To specify a style sheet, supply a value of “stylesheet”. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 28 How to use a style sheet A style sheet can be used to define the font styles that are applied to the text of an HTML page. To identify the location of the style sheet that should be used for a page, you use the Link tag within the Head tags of the page. This type of style sheet can be referred to as an external style sheet, or linked style sheet, and it is actually the top style sheet in a series of cascading style sheets. An external style sheet is typically stored in its own directory, and css is used as the extension for its file name. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 29 A form displayed in a browser before the user enters data Description A form contains one or more controls such as text boxes, buttons, check boxes, and list boxes. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 30 The HTML code for the form <p>Here's a form that contains two text boxes and a button:</p> <form action="entry.jsp" method="get"> <p> First name: <input type="text" name="firstName"><br> Last name: <input type="text" name="lastName"> <input type="submit" value="Submit"> </p> </form> Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 31 Tags for working with a simple form Tag <form> </form> <input> Description Defines the start and end of the form. Defines the input type. Attributes of the Form tag Attribute action method Description The Action attribute specifies the URL of the servlet or JSP that will be called when the user clicks on the Submit button. The Method attribute specifies the HTTP method that the browser will use for the HTTP request. The default method is the Get method, but the Post method is also commonly used. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 32 Common control attributes Attribute name value Description The name of the control. When writing Java code, you can use this attribute to refer to the control. The default value of the control. This varies depending on the type of control. For a text box, this attribute sets the default text that’s displayed in the box. For a button, this attribute sets the text that’s displayed on the button. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 33 The code for three types of text controls <p>Here's a form that contains a text box and a hidden text box:</p> <form action="checkPassword" method="get"> Username: <input type="text" name="username" value="jsmith"><br> Password: <input type="password" name="password" value="opensesame"><br> <input type="hidden" name="productCode" value="jr01"><br> </form> The text controls displayed in a browser Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 34 Attributes of text controls Attribute type name value size maxlength Description Specifies the type of input control. Acceptable types for text boxes are Text, Password, and Hidden. Specifies the name of the control. This is the name that is used to refer to the data in the control from a servlet or JSP. Specifies the value of data in the control. The width of the text control field in characters based on the average character width of the font. The maximum number of characters that can be entered into the text box. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 35 How to code text boxes, password boxes, and hidden fields The Type attribute identifies the type of text box to be used. A value of Text creates a standard text box. A value of Password creates a password box that displays asterisks instead of text. And a value of Hidden creates a hidden field that can store text but isn’t shown by the browser. For a standard text box or password box, you can use the Value attribute to provide a default value. For a hidden field, you always use the Value attribute to supply a value that can be used by a servlet or JSP. Since the Size attribute specifies an approximate number of characters, you may want to make a text box slightly larger than necessary to make sure that all characters will fit within the box. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 36 The code for three types of buttons <input type="submit" value="Submit"> <input type="reset" value="Reset"> <input type="button" value="Validate" onclick="validate(this.form)"> The buttons displayed in a browser Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 37 The code for two submit buttons on the same page <form action="displayQuickOrder" method="post"> <input type="submit" name="continue" value="Continue Shopping"> </form> <form action="checkUser" method="post"> <input type="submit" name="checkout" value="Checkout"> </form> The buttons displayed in a browser Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 38 Attributes of the buttons Attribute type onclick Description Specifies the type of input control. Acceptable types are Submit, Reset, and Button. Specifies the JavaScript method that the button will execute when the user clicks the button. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 39 How to code buttons The Type attribute identifies the type of button to be used. A Type attribute of Submit creates a submit button that activates the Action attribute of the form when it’s clicked. A Type attribute of Reset creates a reset button that resets all controls on the form to their default values when it’s clicked. A Type attribute of Button creates a JavaScript button. When this type of button is clicked, the JavaScript method that’s specified by the OnClick attribute of the button is executed. To pass the current form to a JavaScript method in the OnClick attribute, you can use the this keyword and the form keyword. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 40 The code for four checkboxes and three radio buttons <form action="addToMailingList" method="get"> <input type="checkbox" name="addEmail" checked> Yes, add me to your mailing list.<br> <br> Contact me by:<br> <input type="radio" name="contactVia" value="Email">Email <input type="radio" name="contactVia" value="Postal Mail">Postal mail <input type="radio" name="contactVia" value="Both" checked>Both<br> <br> I'm interested in these types of music:<br> <input type="checkbox" name="rock">Rock<br> <input type="checkbox" name="country">Country<br> <input type="checkbox" name="bluegrass">Bluegrass<br> </form> Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 41 The check boxes and radio buttons when displayed in a browser Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 42 Attributes of the buttons Attribute type checked Description Specifies the type of control. A value of Checkbox creates a check box while a value of Radio creates a radio button. Selects the control. When several radio buttons share the same name, only one radio button can be selected at a time. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 43 How to code check boxes and radio buttons You can use check boxes to allow the user to supply a true/false value. You can use radio buttons to allow a user to select one option from a group of options. To create a group of radio buttons, use the same name for all of the radio buttons. If you don’t group radio buttons, more than one can be on at the same time. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 44 The code for a combo box <form action="writeCountry" method="get"> Select a country:<br> <select name="country"> <option value="USA" selected>United States <option value="Canada">Canada <option value="Mexico">Mexico </select><br> </form> The combo box displayed in a browser Attributes of the Option tag Attribute selected Description Selects the option. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 45 How to convert a combo box to a list box <select name="country" multiple> The combo box displayed as a list box Attributes of the Select tag Attribute multiple Description Converts a combo box to a list box. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 46 How to code combo boxes and list boxes A combo box provides a drop-down list that lets the user select a single option. A list box provides a list of options and lets the user select one or more of these options. To select adjacent options from a list box, the user can click the top option, hold down the Shift key, and click the bottom option. To select non-adjacent options from a list box, the user can click one option, hold down the Ctrl key, and click other options. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 47 The code for a text area Comments:<br> <textarea name="comment" rows="5" cols="60"></textarea> The text area displayed in a browser Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 48 Attributes of the TextArea tag Attribute rows cols Description Specifies the number of visible lines in the text area. If the number of lines in the text box exceeds this setting, the text area will display a vertical scroll bar. Specifies the width of the text area based on the average character width of the font that’s being used. Description A text area is similar to a text box, but it can display multiple lines of text. To specify a default value for a text area, you can code the text within the opening and closing TextArea tags. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 49 An HTML page for a survey Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 50 Code that controls the tab order of the survey page <input type="text" name="firstName" size="20" tabindex="1"> <input type="text" name="lastName" size="20" tabindex="2"> <input type="text" name="emailAddress" size="20" tabindex="3"> <input type=radio name="heardFrom" value="Search Engine" tabindex="4"> <input type=submit value="Submit" tabindex="5"> Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 51 How to set the tab order of controls The tab order determines the sequence in which the controls on a form will receive the focus when the Tab key is pressed. By default, the tab order is the same as the sequence in which the controls are coded in the HTML document. To modify the default tab order, you can use the TabIndex attribute of any visible control. Then, if you omit the TabIndex attribute for some controls, they will be added to the tab order after the controls that have TabIndex attributes. The TabIndex attribute only works for the first radio button in a group. Murach’s Java Servlets/JSP (2nd Ed.), C4 © 2008, Mike Murach & Associates, Inc. Slide 52