Introducing HTML
Introducing HTML
HTML stands for Hypertext Markup Language, and it is the most widely used language to write Web Pages. As its name suggests, HTML is a markup language. Hypertext refers to the way in which Web pages (HTML documents) are linked together. When you click a link in a Web page, you are using hypertext. Markup Language describes how HTML works. With a markup language, you simply "mark up" a text document with tags that tell a Web browser how to structure it to display
You have basic HTML document now, to see some result put the following code in title and body tags. <html> <head> <title>This is document title</title> </head> <body> <h1>This is a heading</h1> <p>Document description goes here.....</p> </body> </html>
Here <html>, <head>,...<p>, <h1> etc. are called HTML tags. HTML tags are building blocks of an HTML document NOTE: One HTML file can have extension as .htm or .html. So you can use either of them based on your comfort.
The <body>...</body> elements, which contain the real content of the document that you see on your screen. <html>, <body> etc. are called HTML tags or HTML elements
Every tag consists of a tag name, sometimes followed by an optional list of tag attributes , all placed between opening and closing brackets (< and >). The simplest tag is nothing more than a name appropriately enclosed in brackets, such as <head> and <i>. More complicated tags contain one or more attributes , which specify or modify the behaviour of the tag.
According to the HTML standard, tag and attribute names are not casesensitive. There's no difference in effect between <head>, <Head>, <HEAD>, or even <HeaD>; they are all equivalent. But with XHTML, case is important: all current standard tag and attribute names are in lowercase
Remember that before an opening <html> tag, an XHTML document can contain the optional XML declaration, and it should always contain a DOCTYPE declaration indicating which version of XHTML it uses.
<head>
<body>
As such, start and end HTML tags enclose all the other HTML tags you use to describe the Web page.
<base> tag
The <object> tag is designed to include images, JavaScript objects, Flash animations, MP3 files, QuickTime movies and other components of a page. The HTML <object> tag is used to embed multimedia in an HTML document. The <param> tag is also used along with this tag to define various parameters. Example: <object title="Test Object." classid="java.class"> <param name="audio" value="music.wav" /> <param name="width" value="600" /> <param name="height" value="400" /> </object>
 The <link> tag is used to link to an external file, such as a style sheet or JavaScript file.
 The <script> tag is used to include JAVAScript or VBScript inside the document.  The <meta> tag includes information about the document such as keywords and a description, which are particularly helpful for search applications.
Example: Here is the example of using body tag. <body> <p>This is a paragraph tag.</p> </body>
Specifying Keywords: We specify keywords which will be used by the search engine to search a web page. So using following tag you can specify important keywords related to your page. <head> <meta name="keywords" content="HTML, meta tags, metadata" /> </head> Document Description: This is again important information and many search engine use this information as well while searching a web page. So you should give an appropriate description of the page. <head> <meta name="description" content="Learn about Meta Tags." /> </head
Document Revision date: This information tells about last time the document was updated. <head> <meta name="revised" content="Tutorialspoint, 6/12/2006" /> </head> Document Refreshing: You can specify a duration after which your web page will keep refreshing. If you want your page keep refreshing after every 10 seconds then use the following syntax. <head> <meta http-equiv="refresh" content="10" /> </head>
Page Redirection: You can specify a page redirection using Meta Tag. Following is an example of redirecting current page to another page. You can specify a duration after which page will be redirected. <head> <meta http-equiv="refresh" content="10; url=http://www.tutorialspoint.com" /> </head> If you don't provide a duration then page will be redirected immediately Setting Cookies: You can use Meta Tag to store cookies on client side later information can be used by then Web Server to track a site visitor. <head> <meta http-equiv="cookie" content="userid=xyz; expires=Wednesday, 08-Aug-00 23:59:59 GMT; /> </head> If you do not include the expiration date and time, the cookie is considered a session cookie and will be deleted when the user exits the browser.
Setting Author Name: You can set an author name in a web page using Meta Tag. See an example below: <head> <meta name="author" content="Mahnaz Mohtashim" /> </head>
HTML Attributes
 Attributes are another important part of HTML markup. An attribute is used to define the characteristics of an element and is placed inside the element's opening tag. All attributes are made up of two parts: a name and a value:  The name is the property you want to set. For example, the <font> element in the example carries an attribute whose name is face, which you can use to indicate which typeface you want the text to appear in.
The value is what you want the value of the property to be. The first example was supposed to use the Arial typeface, so the value of the face attribute is Arial.
The value of the attribute should be put in double quotation marks, and is separated from the name by the equals sign. You can see that a color for the text has been specified as well as the typeface in this <font> element: <font face="arial" color="#CC0000">
Core Attributes:
 The four core attributes that can be used on the majority of HTML elements (although not all) are:     id title class style
The id Attribute:
 The id attribute can be used to uniquely identify any element within a page ( or style sheet ). There are two primary reasons that you might want to use an id attribute on an element:  If an element carries an id attribute as a unique identifier it is possible to identify just that element and its content.
If you have two elements of the same name within a Web page (or style sheet), you can use the id attribute to distinguish between elements that have the same name.
We will discuss style sheet in separate tutorial. For now, the id attribute could be used to distinguish between two paragraph elements, like so: <p id="html">This para explains what is HTML</p> <p id="css">This para explains what is Casecading Style Sheet</p
Note that there are some special rules for the value of the id attribute, it must: Begin with a letter (A.Z or a.z) and can then be followed by any number of letters, digits (0.9), hyphens, underscores, colons, and periods. Remain unique within that document; no two attributes may have the same value within that HTML document
Internationalization Attributes:
 There are three internationalization attributes, which are available to most (although not all) XHTML elements.
dir
lang xml:lang
rtl Right to left (for languages such as Hebrew or Arabic that are read right to left)
Example: <html dir=rtl> <head> <title>Display Directions</title> </head> <body> This is how IE 5 renders right-to-left directed text. </body> </html>
Example: <html lang=en> <head> <title>English Language Page</title> </head> <body> This page is using English Language </body> </html>
Generic Attributes
You can use align attribute to align your paragraphs. <p align="left">This is left aligned.</p> <p align="center">This is center aligned.</p> <p align="right">This is right aligned.</p> <p align="justify">This is jutified. This works when you have multiple lines in your paragraph and you want to justfy all the lines so that they can look more nice.</p>
Example: Hello<br /> You come most carefully upon your hour.<br /> Thanks<br /> Mahnaz
Nonbreaking Spaces:
 Suppose you were to use the phrase "12 Angry Men." Here you would not want a browser to split the "12" and "Angry" across two lines:  In cases where you do not want the client browser to break text, you should use a nonbreaking space entity ( ) instead of a normal space. For example, when coding the "12 Angry Men" paragraph, you would use something similar to the following code:  <p>A good example of this technique appears in the movie "12 Angry Men."</p>
Again <hr /> tag is an example of an empty element, where you do not need opening and closing tags, as there is nothing to go in between them.
Presentational Tags:
 If you use a word processor, you are familiar with the ability to make text bold, italicized, or underlined; these are just three of the ten options available to indicate how text can appear in HTML and XHTML.  Bold Text - The <b> Element:  Anything that appears in a <b>...</b> element is displayed in bold, like the word bold here:  <p>The following word uses a <b>bold</b> typeface.</p>  This will produce following result:  The following word uses a bold typeface.
Italic Text - The <i> Element: Anything that appears in a <i>...</i> element is displayed in italicized, like the word italicized here: <p>The following word uses a <i>italicized</i> typeface.</p>
typeface.</p>
The <div> element is used to group block-level elements together: <div id="menu" align="middle" > <a href="/index.htm">HOME</a> | <a href="/about/contact_us.htm">CONTACT</a> | <a href="/about/index.htm">ABOUT</a> </div> <div id="content" align="left" bgcolor="white"> <h5>Content Articles</h5> <p>Actual content goes here.....</p> </div>
The <span> element, on the other hand, can be used to group inline elements only. So, if you had a part of a sentence or paragraph you wanted to group together you could use the <span> element. <div><p>This is the example of <span style="color:green">span tag</span> and the <span style="color:purple">div tag</span> alongwith CSS</p></div>
<p>The following description of XHTML is taken from the W3C Web site:</p> <blockquote> XHTML 1.0 is the W3C's first Recommendation for XHTML, following on from earlier work on HTML 4.01, HTML 4.0, HTML 3.2 and HTML 2.0. </blockquote>
You can use the cite attribute on the <blockquote> element to indicate the source of the quote. <p>The following description of XHTML is taken from the W3C Web site:</p> <blockquote cite="http://www.w3.org/markup/"> XHTML 1.0 is the W3C's first Recommendation for XHTML, following on from earlier work on HTML 4.01, HTML 4.0, HTML 3.2 and HTML 2.0. </blockquote>
Short Quotations - The <q> Element : The <q> element is intended to be used when you want to add a quote within a sentence rather than as an indented block on its own. <p>Amit is in Spain, <q>He is their at my home. I think I am wrong</q>.</p> The <q> element can also carry the cite attribute. The value should be a URL pointing to the source of the quote.
Inline elements - Inline elements, on the other hand, can appear within sentences and do not have to appear on a new line of their own. The <b>, <i>, <u>, <em>, <strong>, <sup>, <sub>, <big>, <small>, <li>, <ins>, <del>, <code>, <cite>, <dfn>, <kbd>, and <var> elements are all inline elements.
HTML Comments
 Comments are piece of code which is ignored by any web browser. It is good practice to comment your code, especially in complex documents, to indicate sections of a document, and any other notes to anyone looking at the code. Comments help you and others understand your code.  HTML Comment lines are indicated by the special beginning tag <!-- and ending tag --> placed at the beginning and end of EVERY line to be treated as a comment.  Comments do not nest, and the double-dash sequence "--" may not appear inside a comment except as part of the closing --> tag. You must also make sure that there are no spaces in the start-of-comment string.
For example: Given line is a valid comment in HTML <!-- This is commented out --> But following line is not a valid comment and will be displayed by the borwser. This is because there is a space between the left angle bracket and the exclamation mark. < !-- This is commented out -->
Multiline Comments:
 You have seen how to comment a single line in HTML. You can comment multiple lines by the special beginning tag <!-- and ending tag --> placed before the first line and end of the lastline to be treated as a comment.  For example:  <!- This is a multiline comment <br />  and can span through as many as lines you like.  -->
Conditional Comments :
 Conditional comments only work in Explorer on Windows, and are thus excellently suited to give special instructions meant only for Explorer on Windows. They are supported from Explorer 5 onwards, and it is even possible to distinguish between 5.0, 5.5 and 6.0.  Conditional comments work as follows:  <!--[if IE 6]>  Special instructions for IE 6 here  <![endif]-->
Similarly if you are using Casecading Style Sheet in your HTML code then it is recommended to put that style sheet code inside proper HTML Comments to make old browser works properly. For example: <style> <!- img{ border:0px; } //--> </style>
HTML Fonts
 Font face and color depends entirely on the computer and browser that is being used to view your page. But the <font> tag is used to add style, size, and color to the text on your site. You can use a <basefont> tag to set all of your text to the same size, face, and color.  The font tag is having three attributes called size, color, and face to customize your fonts.  To change any of the font attributes at any time within your page, simply use the <font> tag.  The text that follows will remain changed until you close with the </font> tag. You can change any or all of the font attributes at the one time, by including all the required changes within the one <font> tag.
NOTE: The font and basefont tags are deprecated and it is supposed to be removed in a future version of HTML. So it should not be used. Its is suggested to use css styles to manipulate your font.
Font Size:
 You can set the size of your font with size attribute. The range of accepted values is from 1(smallest) to 7(largest). The default size of a font is 3.  Example:  <font size="1">Font size="1"</font>  <font size="2">Font size="2"</font>  <font size="3">Font size="3"</font>  <font size="4">Font size="4"</font>  <font size="5">Font size="5"</font>  <font size="6">Font size="6"</font>  <font size="7">Font size="7"</font>
SPECIFY THE RELATIVE FONT SIZE. <font size="+n"> or <font size="-n">: You can specify how many sizes larger or how many sizes smaller than the preset font size should be. Example: <font size="-1">Font size="-1"</font> <font size="+1">Font size="+1"</font> <font size="+2">Font size="+2"</font> <font size="+3">Font size="+3"</font> <font size="+4">Font size="+4"</font>
Font Face:
 You can set any font you like using face attribute but be aware that if the user viewing the page doesn't have the font installed, they will not be able to see it.  Instead they will default to Times New Roman of your font with size attribute. See below few examples on using different font face  <font face="Times New Roman" size="5">Times New Roman</font>  <font face="Verdana" size="5">Verdana</font>  <font face="Comic sans MS" size="5">Comic Sans MS</font>  <font face="WildWest" size="5">WildWest</font>
Font Color:
 You can set any font color you like using color attribute. You can specify the color that you want by either the color name or hexadecimal code for that color.  <font color="#FF00FF">This text is hexcolor #FF00FF</font>  <font color="red">This text is red</font>
HTML Colors
 Colors are very important to give a good look and feel to your website. You can specify colors on page level using <body> tag or you can set colors for individual tags.  The <body> tag has following attributes which can be used to set different colors:  bgcolor: Sets a color for the background of the page.  text: Sets a color for the body text.  alink: Sets a color for active links or selected links.  link: Sets a color for linked text.  vlink: Sets a color for visited links - that is, for linked text that you have already clicked on.
HTML Images
 Images are very important to beautify as well as to depicts many concepts on your web page. Its is true that one single image is worth than thuasands of words. So as a Web Developer you should have clear understanding on how to use images in your web page
width: sets width of the image. This will have a value like 10 or 20%etc. height: sets height of the image. This will have a value like 10 or 20% etc. border: sets a border around the image. This will have a value like 1 or 2 etc. src: specifies URL of the image file. alt: this is an alternate text which will be displayed if image is missing. align: this sets horizontal alignment of the image and takes value either left, right or center. valign: this sets vertical alignment of the image and takes value either top, bottom or center.
hspace: horizontal space around the image. This will have a value like 10 or 20%etc. vspace: vertical space around the image. This will have a value like 10 or 20%etc. name: name of the image with in the document. id: id of the image with in the document. style: this will be used if you are using CSS. title: specifies a text title. The browser, perhaps flashing the title when the mouse passes over the link. ismap and usemap: These attributes for the <img> tag tell the browser that the image is a special mouse-selectable visual map of one or more hyperlinks, commonly known as an image map
<img src="http://www.tutorialspoint.com/images/h tml.gif" alt="HTML Tutorial" /> This will produce following result:
You can use vspace or hspace attributes if you want to keep some distance between text and image
<p>This is the first paragraph that appears above the paragraph with the image!</p> <p><img src="http://www.tutorialspoint.com/images/html.gif" vspace="10" hspace="15" width="75" height="75" alt="HTML Tutorial" align="right"> The image will appear along the right hand side of the paragraph. As you can see this is very nice for adding a little eye candy that relates to the specified paragraph.</p> <p>The left and right image-alignment values tell the browser to place an image against the left or right margin, respectively, of the current text flow. The browser then renders subsequent document content in the remaining portion of the flow adjacent to the image. The net result is that the document content following the image gets wrapped around the image. </p>
Anchor Attributes:
 href: specifies the URL of the target of a hyperlink. Its value is any valid document URL, absolute or relative, including a fragment identifier or a JavaScript code fragment.  target: specify where to display the contents of a selected hyperlink. If set to "_blank" then a new window will be opened to display the loaded page, if set to "_top" or "_parent" then same window will be used to display the loaded document, if set to "_self" then loads the new page in current window. By default its "_self
event: attributes like onClick, onMouseOver etc. are used to trigger any Javascript ot VBscript code. title: attribute lets you specify a title for the document to which you are linking. The value of the attribute is any string, enclosed in quotation marks. The browser might use it when displaying the link, perhaps flashing the title when the mouse passes over the link.
accesskey: attribute attribute provides a keyboard shortcut that can be used to activate a link. For example, you could make the T key an access key so that when the user presses either the Alt or Ctrl key on his keyboard (depending on his operating system) along with the T key, the link gets activated.
A Simple Example:
 <a href="http://www.tutorialspoint.com/" target="_blank" >TP Home</a> |  <a href="http://www.amrood.com/" target="_self" >AMROOD Home</a> |  <a href="http://www.change-images.com/" target="_top" >Change Images Home</a>
Create a named anchor Anchor names must be unique within a document. Anchor names are case-sensitive. The following symbols can be included in an anchor name. hyphen(-), underscore(_), colon(:), period(.) name="anchor_name" Anchor names must start in the alphabet. name="a001"
Link to a named anchor Type a number sign (#) and the name of the anchor. href="#a001"
link - standard link - to a page the visitor hasn't been to yet. (standard color is blue - #0000FF). vlink - visited link - to a page the visitor has been to before. (standard color is purple - #800080). alink - active link - the color of the link when the mouse is on it. (standard color is red - #FF0000).
The first technique would look like this: Click <a href="http://www.yahoo.com"><font color="FF00CC">here</font></a> to go to yahoo. Note: It is important that both the <font> and the </font> tags are between the <a href> and </a> tags. The second technique would look like this: Click <a href="http://www.yahoo.com" style="color: rgb(0,255,0)">here</a> to go to yahoo. Note: The RGB numbers indicate amounts of red, green, and blue using values between 0 and 255.
Now, since neither of the two methods covers all browsers, we need to use both techniques at once. This example will work on all browsers: Click <a href="http://www.yahoo.com" style="color: rgb(0,255,0)"><font color="FF00CC">here</font></a> to go to yahoo.
HTML Tables
 Tables are very useful to arrange in HTML and they are used very frequently by almost all web developers. Tables are just like spreadsheets and they are made up of rows and columns.  You will create a table in HTML/XHTML by using <table> tag. Inside <table> element the table is written out row by row. A row is contained inside a <tr> tag . which stands for table row. And each cell is then written inside the row element using a <td> tag . which stands for table data.
<table border="1"> <tr> <td>Row 1, Column 1</td> <td>Row 1, Column 2</td> </tr> <tr> <td>Row 2, Column 1</td> <td>Row 2, Column 2</td> </tr> </table>
<table border="1"> <tr> <th>Name</th> <th>Salary</th> </tr> <tr> <td>Ramesh Raman</td> <td>5000</td> </tr> <tr> <td>Shabbir Hussein</td> <td>7000</td> </tr> </table>
<table border="1" cellpadding="5" cellspacing="5"> <tr> <th>Name</th> <th>Salary</th> </tr> <tr> <td>Ramesh Raman</td> <td>5000</td> </tr> <tr> <td>Shabbir Hussein</td> <td>7000</td> </tr> </table>
Tables Backgrounds
 You can set table background using of the following two ways:  Using bgcolor attribute - You can set background color for whole table or just for one cell.  Using background attribute - You can set background image for whole table or just for one cell.  NOTE:You can set border color also using bordercolor attribute
<table border="5" bordercolor="green" bgcolor="gray"> <tr> <th>Column 1</th> <th>Column 2</th> <th>Column 3</th> </tr> <tr><td rowspan="2">Row 1 Cell 1</td> <td bgcolor="red">Row 1 Cell 2</td><td>Row 1 Cell 3</td></tr> <tr><td>Row 2 Cell 2</td><td>Row 2 Cell 3</td></tr> <tr><td colspan="3">Row 3 Cell 1</td></tr> </table>
<table width="400" border="1"> <tr> <th align="left">Money spent on....</th> <th align="right">January</th> <th align="right">February</th> </tr> <tr> <td align="left">Clothes</td> <td align="right">$241.10</td> <td align="right">$50.20</td> </tr> <tr> <td align="left">Make-Up</td> <td align="right">$30.00</td> <td align="right">$44.45</td> </tr> <tr> <td align="left">Food</td> <td align="right">$730.40</td> <td align="right">$650.00</td> </tr> <tr> <th align="left">Sum</th> <th align="right">$1001.50</th> <th align="right">$744.65</th> </tr> </table>
Content Summary
 The following HTML table defines a summary of the content of the table:
<!DOCTYPE html> <html> <body> <table border="1" summary="Monthly savings for the Flintstones family"> <tr> <th>Month</th> <th>Savings</th> </tr> <tr> <td>January</td> <td>$100</td> </tr> <tr> <td>February</td> <td>$80</td> </tr> </table> <p><b>Note:</b> The summary attribute is not supported in HTML5.</p>
</body>
<!DOCTYPE html> <html> <body> <table border="1"> <colgroup> <col span="2" style="background-color:red"> <col style="background-color:yellow"> </colgroup> <tr> <th>ISBN</th> <th>Title</th> <th>Price</th> </tr> <tr> <td>3476896</td> <td>My first HTML</td> <td>$53</td> </tr> <tr> <td>5869207</td> <td>My first CSS</td> <td>$49</td> </tr> </table> </body> </html>
<TABLE CELLPADDING=6 RULES=GROUPS FRAME=BOX> <THEAD> <TR><TH>Weekday</TH><TH>Date</TH><TH>Manager</TH> <TH>Qty</TH></TR> </THEAD> <TBODY> <TR> <TD>Mon</TD> <TD>09/11</TD> <TD>Kinjal</TD><TD>639</TD></TR> <TR> <TD>Tue</TD> <TD>09/12</TD> <TD>Leena</TD><TD>596</TD></TR> <TR> <TD>Wed</TD> <TD>09/13</TD> <TD>Ruma</TD><TD>1135</TD></TR> <TR> <TD>Thu</TD> <TD>09/14</TD> <TD>Sushant</TD><TD>1002</TD></TR> <TR> <TD>Fri</TD> <TD>09/15</TD> <TD>Ram</TD><TD>908</TD></TR> <TR> <TD>Sat</TD> <TD>09/16</TD> <TD>Leena</TD><TD>371</TD></TR> <TR> <TD>Sun</TD> <TD>09/17</TD> <TD>Sushant</TD> <TD>272</TD></TR> </TBODY> <TFOOT> <TR> <TH ALIGN=LEFT COLSPAN=3>Total</TH> <TH>4923</TH> </TR> </TFOOT> </TABLE>
Type Value: disc square circle Specifies the kind of marker to use in the list
<!DOCTYPE html> <html> <body> <ul type="square"> <li>Coffee</li> <li>Tea</li> <li>Milk</li> </ul> <ul type="circle"> <li>Coffee</li> <li>Tea</li> <li>Milk</li> </ul> <p><b>Note:</b> The type attribute is deprecated in HTML 4, and is not supported in HTML5. Use CSS instead.</p> </body> </html>
reversedSpecifies that the list order should be descending (9,8,7...) Start Specifies the start value of an ordered list Type Specifies the kind of marker to use in the list
<!DOCTYPE html> <html> <body> <ol reversed> <li>Coffee</li> <li>Tea</li> <li>Milk</li> </ol> <p><strong>Note:</strong> The reversed attribute of the ol tag is supported only in Chrome and Safari 6.</p> </body> </html>
<!DOCTYPE html> <html> <body> <ol start="50"> <li>Coffee</li> <li>Tea</li> <li>Milk</li> </ol>
<!DOCTYPE html> <html> <body> <ol type="I"> <li>Coffee</li> <li>Tea</li> <li>Milk</li> </ol>
</body> </html>
<!DOCTYPE html> <html> <body> <dl> <dt>Coffee</dt> <dd>Black hot drink</dd> <dt>Milk</dt> <dd>White cold drink</dd> </dl> </body> </html>
HTML Forms
 HTML Forms are required when you want to collect some data from the site visitor. For example registration information: name, email address, credit card, etc.  A form will take input from the site visitor and then will post your back-end application such as CGI, ASP Script or PHP script etc. Then your back-end application will do required processing on that data in whatever way you like.  Form elements are like text fields, textarea fields, drop-down menus, radio buttons, checkboxes, etc. which are used to take information from the user.
A simple syntax of using <form> is as follows: <form action="back-end script" method="posting method"> form elements like input, textarea etc. </form>
name: This is the name of the form. action: Here you will specify any script URL which will receive uploaded data. method: Here you will specify method to be used to upload data. It can take various values but most frequently used are GET and POST. target: It specifies the target page where the result of the script will be displayed. It takes values like _blank, _self, _parent etc. enctype: You can use the enctype attribute to specify how the browser encodes the data before it sends it to the server. Possible values are like:
o application/x-www-form-urlencoded - This is the standard method most forms use. It converts spaces to the plus sign and nonalphanumeric characters into the hexadecimal code for that character in ASCII text. o mutlipart/form-data - No characters are encoded. This value is required when you are using forms that have a file upload control text/plain- Spaces are converted to "+" symbols, but no special characters are encoded
There are different types of form controls that you can use to collect data from a visitor to your site. Text input controls Buttons Checkboxes and radio buttons Select boxes File select boxes Hidden controls Submit and reset button
<form action="/cgi-bin/hello_get.cgi" method="get"> First name: <input type="text" name="first_name" /> <br> Last name: <input type="text" name="last_name" /> <input type="submit" value="submit" /> </form>
Following is the list of attributes for <input> tag. type: Indicates the type of input control you want to create. This element is also used to create other form controls such as radio buttons and checkboxes. name: Used to give the name part of the name/value pair that is sent to the server, representing each form control and the value the user entered. value: Provides an initial value for the text input control that the user will see when the form loads. size: Allows you to specify the width of the text-input control in terms of characters. maxlength: Allows you to specify the maximum number of characters a user can enter into the text box.
<form action="/cgi-bin/hello_get.cgi" method="get"> Login : <input type="text" name="login" /> <br> Password: <input type="text" name="password" /> <input type="submit" value="submit" /> </form>
Here is the example: <form action="http://www.example.com/test.asp" method="get"> <input type="submit" name="Submit" value="Submit" /> <br /><br /> <input type="reset" value="Reset" /> <input type="button" value="Button" /> </form>
You can use <button> element to create various buttons. Here is the syntax: <form action="http://www.example.com/test.asp" method="get"> <button type="submit">Submit</button> <br /><br /> <button type="reset"> Reset </button> <button type="button"> Button </button> </form>
Following is the list of important radiobox attributes: type: Indicates that you want to create a radiobox. name: Name of the control. value: Used to indicate the value that will be sent to the server if this option is selected. checked: Indicates that this option should be selected by default when the page loads.
Following is the list of important attributes of <select>: name: This is the name for the control. size: This can be used to present a scrolling list box. multiple: If set to "multiple" then allows a user to select multiple items from the menu. Following is the list of important attributes of <option>: value: The value that is sent to the server if this option is selected. selected: Specifies that this option should be the initially selected value when the page loads. label: An alternative way of labeling options.
VALUE
       <SELECT NAME="partnumber"> <OPTION VALUE="7382">steam turbine <OPTION VALUE="2928">resistor array <OPTION VALUE="3993">widget analyzer <OPTION VALUE="9398">fiber identifier </SELECT> In this example, if you selected the first option, "steam turbine", then the name/value pair partnumber=7382 is sent to the scripting code.
SELECTED
 In this example, the third item ("widget analyzer") is the default item:  <SELECT NAME="partnumber">  <OPTION VALUE="7382 >steam turbine  <OPTION VALUE="2928 >resistor array  <OPTION VALUE="3993 SELECTED >widget analyzer  <OPTION VALUE="9398 >fiber identifier  </SELECT>
HIDDEN FIELD
 Hidden fields are similar to text fields, with one very important difference! The difference is that the hidden field does not show on the page. Therefore the visitor can't type anything into a hidden field, which leads to the purpose of the field: To submit information that is not entered by the visitor.
The name setting adds an internal name to the field so the program that handles the form can identify the fields. The value setting defines what will be sent once the form is submitted. hidden
<html> <head> <title>My Page</title> </head> <body> <form name="myform" action="http://www.mydomain.com/myformhandler.cgi" method="POST"> <div align="center"> <input type="text" size="25" value="Enter your name here!"> <input type="hidden" name="Language" value="English"> <br><br> </div> </form> </body> </html>
The hidden field does not show, but still, when the form is submitted the hidden field is sent with it.
In this example the hidden field would tell the program that handles the form, that the users preferred language is English.
<!DOCTYPE html> <html> <body> <form action="demo_form.asp"> Email: <input type="text" name="email"><br> Country: <input type="text" name="country" value="Norway" readonly><br> <input type="submit" value="Submit"> </form> </body> </html>
DISABLED
 DISABLED does same thing but takes it further: user cannot use the field in any way, not to highlight the text for copying, not to select the checkbox, not to submit the form. In fact, a disabled field is not even sent if the form is submitted.  <INPUT NAME="realname VALUE="Hi There"  DISABLED>
TABINDEX = integer Normally, when the user tabs from field to field in a form (in a browser that allows tabbing, not all browsers do) the order is the order the fields appear in the HTML code. However, sometimes you want the tab order to flow a little differently. In that case, you can number the fields using TABINDEX. The tabs then flow in order from lowest TABINDEX to highest.
<FIELDSET> name: <INPUT NAME="realname"><BR> email: <INPUT NAME="email"> </FIELDSET><P> <FIELDSET> favorite color: <INPUT NAME="favecolor"><BR> <INPUT TYPE=CHECKBOX NAME="onions"> like green onions<BR> <INPUT TYPE=CHECKBOX NAME="cookies"> like cookies<BR> <INPUT TYPE=CHECKBOX NAME="kimchee"> like kim chee<BR> </FIELDSET><P> <FIELDSET> other comments:<BR> <TEXTAREA NAME="comments" ROWS=5 COLS=25></TEXTAREA> </FIELDSET>
<LEGEND>:
 <LEGEND> is used with <FIELDSET> to give a title to each set of fields. Attribute of <LEGEND> is ALIGN. ALIGN align the <LEGEND> text left, center, or right
<FIELDSET> <LEGEND ALIGN=LEFT>Personal Stuff</LEGEND><P> name: <INPUT NAME="realname"><BR> email: <INPUT NAME="email"> </FIELDSET><P> <FIELDSET> <LEGEND ALIGN=CENTER>Survey</LEGEND><P> favorite color: <INPUT NAME="favecolor"><BR> <INPUT TYPE=CHECKBOX NAME="favecolor"> like green onions<BR> <INPUT TYPE=CHECKBOX NAME="onions"> like cookies<BR> <INPUT TYPE=CHECKBOX NAME="kimchee"> like kim chee<BR> </FIELDSET><P> <FIELDSET> <LEGEND ALIGN=RIGHT>Misc</LEGEND><P> other comments:<BR> <TEXTAREA NAME="comments" ROWS=5 COLS=25></TEXTAREA> </FIELDSET>
INTRODUCTION TO FRAMES
 Frames allow you to divide the page into several rectangular areas and to display a separate document in each rectangle. Each of those rectangles is called a "frame".  HTML frames allow authors to present documents in multiple views, which may be independent windows or subwindows.  Multiple views offer designers a way to keep certain information visible, while other views are scrolled or replaced.  For example, within the same window, one frame might display a static banner, a second a navigation menu, and a third the main document that can be scrolled through or replaced by navigating in the second frame.
The disadvantages of using frames are: Frames are not expected to be supported in future versions of HTML i.e. HTML 5.0 Frames are difficult to use. (Printing the entire page is difficult). The web developer must keep track of more HTML documents
The <frameset> tag defines a frameset. The <frameset> element holds one or more <frame> elements. Each <frame> element can hold a separate document. The <frameset> element specifies HOW MANY columns or rows there will be in the frameset, and HOW MUCH percentage/pixels of space will occupy each of them.
<!DOCTYPE html> <html> <frameset cols="25%,*,25%"> <frame src="frame_a.htm"> <frame src="frame_b.htm"> <frame src="frame_c.htm"> </frameset> </html>
<HTML> <HEAD> <TITLE>A Basic Example of Frames</TITLE> </HEAD> <FRAMESET ROWS="75%, *" COLS="*, 40%"> <FRAME SRC="framea.html"> <FRAME SRC="frameb.html"> <FRAME SRC="framec.html"> <FRAME SRC="framed.html"> <NOFRAMES> <H1>No Frames? No Problem!</H1> Take a look at our <A HREF="basic.noframes.html">noframes</A> version. </NOFRAMES> </FRAMESET> </HTML>
<FRAMESET Start the "table of documents". ROWS="75%, *" The table should have two rows. The first row should take up 75% of the height of the page; the second should take up the rest. COLS="*, 40%"> The table should also have two columns. The second column should take up 40% of the width of the page; the first column should take up the rest. <FRAME SRC="framea.html"> <FRAME SRC="frameb.html"> <FRAME SRC="framec.html"> <FRAME SRC="framed.html">
Put the four files into the frames. <NOFRAMES> ... </NOFRAMES> Every framed page should have a no-frames alternative. The <NOFRAMES> content should go inside the outermost<FRAMESET> tag, usually just before the last </FRAMESET>. The most efficient method for noframes content is to link to a page which is specifically designed for no-frames. </FRAMESET> End the frameset.
Rows and columns are described by a list of widths or heights. For example COLS="25%, *, 40%" says that there will be three columns. The first column takes up 25% of the width of the page, the third column takes up 40% of the width of the page, and the asterisk ("*") means "whatever is left over".
<FRAMESET> itself only define how many rows and columns of frames there will be. <FRAME> defines what files will actual go into those frames <FRAMESET> can be nested within another <FRAMESET> to create a "table within a table". By doing this you can create frames that are not strict grids like in the example above. This set of nested framesets creates the popular "title and sidebar" layout.
<FRAME> sets a single frame in the framed page. <FRAME> always goes inside a <FRAMESET> element. The SRC attribute, which is required, indicates the URL of the page that goes in the frame. In most situations you should also use NAME to give the frame a name so that links can target the frame. Attributes used with <FRAME> tag:
SRC
 <FRAME SRC="recipetitlebar.html NAME=TITLE SCROLLING=NO>
target attribute
 The target attribute of the A element specifies the target frame of the link.  <a href="index.html" target="_top">linked text</a>
SCROLLING
 SCROLLING =  YES | NO | AUTO  SCROLLING says if there should be a scroll bar on the right and/or bottom of the frame. YES says there absolutely will be scroll bars, even if they are not needed.  NO says there will not be scroll bars, even if they might be needed.  AUTO is the default: there will be scroll bars on the side and/or bottom as needed.
<FRAMESET ROWS="30%,30%,*"> <FRAME SRC="scrollingYes.html" SCROLLING=YES> <FRAME SRC="scrollingNo.html" SCROLLING=NO> <FRAME SRC="scrollingAuto.html" SCROLLING=AUTO> <NOFRAMES>NOFRAMES stuff </NOFRAMES> </FRAMESET>
NORESIZE
 NORESIZE says that he user cannot make the frame bigger or smaller by sliding the borders. Normally the user can put the mouse over the border and move the border left/right or up/down. NORESIZ E disables that ability. All borders that run along the frame are affected.  For example, this code uses NORESIZE with the frame for the title bar, and so the border along the bottom of the title bar title bar cannot be resized. However, the two frames at the bottom of the page can still be resized by moving the border left and right.
<HTML> <HEAD> <TITLE>Great Recipes</TITLE> </HEAD> <FRAMESET ROWS="20%,*"> <FRAME SRC="recipetitlebar.html NAME=TITLE NORESIZE> <FRAMESET COLS="20%,*"> <FRAME SRC="recipesidebar.html NAME=SIDEBAR> <FRAME SRC="recipes.html NAME=RECIPES> </FRAMESET> <NOFRAMES>NOFRAMES stuff </NOFRAMES> </FRAMESET> </HTML>
FRAMEBORDER
 FRAMEBORDER  = YES | 1 | NO | 0  By default frames have visible borders between them. Sometimes, however, you want the frames to join directly to each other with no border between them then you can specify frameborder= NO | 0
BORDERCOLOR
 BORDERCOLOR = color expression  BORDERCOLOR sets the color of the borders around the frame
<FRAMESET ROWS="*,*,40%,*,*"> <FRAME SRC="bcRow1.html"> <FRAME SRC="bcRow2.html"> <FRAME SRC="bcRow3.html BORDERCOLOR=RED> <FRAME SRC="bcRow4.html"> <FRAME SRC="bcRow5.html"> <NOFRAMES>NOFRAMES stuff </NOFRAMES> </FRAMESET>
MARGINWIDTH MARGINHEIGHT
 MARGINWIDTH = size in pixels  MARGINHEIGHT = size in pixels  MARGINWIDTH an d MARGINHEIGHT control the inside margins of the document in the frame.
<HTML> <TABLE BORDER=1 WIDTH=400 HEIGHT=400 BORDERCOLOR=black> <TR><TD COLSPAN=2 ALIGN=center>Example of Floating Frame</TD></TR> <TR> <TD WIDTH=20%> </td> <TD WIDTH=80%> <IFRAME SRC="shapes.gif" WIDTH="50%" HEIGHT="100 ALIGN=LEFT SCROLLING="auto" NAME="floater" FRAMEBORDER=1> Your browser does not support floating frames. </IFRAME> </TD> </TR> </TABLE> </HTML>
ALIGN ALIGN =TOP|MIDDLE|BOTTOM|LEFT|RIGHT Controls how the floating frame is aligned. TOP, MIDDLE, and BOTTOM alignments make text appear next to the frame, starting at the top, middle, or bottom of the frame. Setting ALIGN to LEFT or RIGHT floats the frame in the left or right margin and allows text to wrap around it FRAMEBORDER : Setting FRAMEBORDER to 1 turns on the floating frames borders; setting it to 0 turns them off
HEIGHT Specifies the height of the floating frame in pixels MARGINHEIGHT Specifies size (in pixels) of the top margin of the floating frame MARGINWIDTH Specifies size (in pixels) of the left margin of the floating frame NAME Gives the floating frame a unique name so it can be targeted by other tags (such as <A>, <FORM>,
SCROLLING Controls the presence of scrollbars on the floating frame. Setting SCROLLING to YES makes the browser always put scrollbars on the floating frame, setting it to NO suppresses the scrollbars, and setting it to the default of AUTO lets the browser decide whether the scrollbars are needed or not. SRC Tells the browser the URL of the HTML file to load into the floating frame. SRC is a required attribute of the <IFRAME> tag WIDTH Specifies the width of the floating frame in pixels
CSS
 CSS is used to control the style of a web document in a simple and easy way.  CSS stands for Cascading Style Sheet.
What is CSS?
 Cascading Style Sheets, fondly referred to as CSS, is a simple design language intended to simplify the process of making web pages presentable.  CSS handles the look and feel part of a web page. Using CSS, you can control the color of the text, the style of fonts, the spacing between paragraphs, how columns are sized and laid out, what background images or colors are used, as well as a variety of other effects.  CSS is easy to learn and understand but it provides powerful control over the presentation of an HTML document. Most commonly, CSS is combined with the markup languages HTML or XHTML
Advantages of CSS:
 CSS saves time - You can write CSS once and then reuse same sheet in multiple HTML pages. You can define a style for each HTML element and apply it to as many Web pages as you want.  Pages load faster - If you are using CSS, you do not need to write HTML tag attributes every time. Just write one CSS rule of a tag and apply to all the occurrences of that tag. So less code means faster download times.  Easy maintenance - To make a global change, simply change the style, and all elements in all the web pages will be updated automatically.
Superior styles to HTML - CSS has a much wider array of attributes than HTML so you can give far better look to your HTML page in comparison of HTML attributes. Multiple Device Compatibility - Style sheets allow content to be optimized for more than one type of device. By using the same HTML document, different versions of a website can be presented for handheld devices such as PDAs and cell phones or for printing. Global web standards - Now HTML attributes are being deprecated and it is being recommended to use CSS. So its a good idea to start using CSS in all the HTML pages to make them compatible to future browsers.
CSS Versions:
 Cascading Style Sheets, level 1 (CSS1) was came out of W3C as a recommendation in December 1996. This version describes the CSS language as well as a simple visual formatting model for all the HTML tags.  CSS2 was became a W3C recommendation in May 1998 and builds on CSS1. This version adds support for media-specific style sheets e.g. printers and aural devices, downloadable fonts, element positioning and tables
You can put CSS Style Rule Syntax as follows: selector { property: value } Example: You can define a table border as follows: table{ border :1px solid #C00; } Here table is a selector and border is a property and given value 1px solid #C00 is the value of that property.
You can define selectors in various simple ways based on your comfort
 The Type Selectors:  This is the same selector we have seen above. Again one more example to give a color to all level 1 headings :  h1 {  color: #36CFFF;  }  The Universal Selectors:  Rather than selecting elements of a specific type, the universal selector quite simply matches the name of any element type :  *{  color: #000000;  }  This rule renders the content of every element in our document in black.
<!DOCTYPE html> <html> <head> <style> p { background-color:yellow; } </style> </head> <body> <h1>Welcome to My Homepage</h1> <div> <p id="firstname">My name is Donald.</p> <p id="hometown">I live in Duckburg.</p> </div> <p>My best friend is Mickey.</p> </body> </html>
<!DOCTYPE html> <html> <head> <style> * { background-color:yellow; } </style> </head> <body> <h1>Welcome to My Homepage</h1> <div class="intro"> <p id="firstname">My name is Donald.</p> <p id="hometown">I live in Duckburg.</p> </div> <p>My best friend is Mickey.</p> </body> </html>
<html><head> <style> h1 i {color: red;} div b {font-style:italic;} p i b {background: yellow;} p * i{text-tranform: uppercase;} </style></head><body> <h1> heading 1 <i> italic</i>heading1</h1> <div> division<b> bold</b> division</div> <p>paragraph<i>italic<b> bold</b> italic</i> paragraph</p> <p><span><i>italic in span in paragraph</i></span></p> </body> </html>
Child selectors
 A child selector matches when an element is the child of some element. A child selector is made up of two or more selectors separated by ">".  The following rule sets the style of all P elements that are children of BODY:  body > P { line-height: 1.3 }  The following example combines descendant selectors and child selectors:  div ol>li p It matches a P element that is a descendant of an LI; the LI element must be the child of an OL element; the OL element must be a descendant of a DIV
<!DOCTYPE html> <html> <head> <style> .intro { background-color:yellow; } </style> </head> <body> <h1>Welcome to My Homepage</h1>
The ID Selectors:
 You can define style rules based on the id attribute of the elements. All the elements having that id will be formatted according to the defined rule.  #black {  color: #000000;  }  This rule renders the content in black for every element with id attribute set to black in our document. You can make it a bit more particular. For example:  h1#black {  color: #000000;  }  This rule renders the content in black for only <h1> elements with id attribute set to black.
<!DOCTYPE html> <html> <head> <style> #firstname { background-color:yellow; } </style> </head> <body> <h1>Welcome to My Homepage</h1>
<div class="intro"> <p id="firstname">My name is Donald.</p> <p id="hometown">I live in Duckburg.</p> </div>
<p>My best friend is Mickey.</p> </body> </html>
<!DOCTYPE html> <html> <head> <style> a[target=_blank] { background-color:yellow; } </style> </head> <body> <p>The link with target="_blank" gets a yellow background:</p> <a href="http://www.w3schools.com">w3schools.com</a> <a href="http://www.disney.com" target="_blank">disney.com</a> <a href="http://www.wikipedia.org" target="_top">wikipedia.org</a> <p><b>Note:</b> For [<i>attribute</i>] to work in IE8 and earlier, a DOCTYPE must be declared.</p> </body> </html>
<!DOCTYPE html> <html> <head> <style> [title] { color:blue; } </style> </head> <body> <h2>Will apply to:</h2> <h1 title="Hello world">Hello world</h1> <a title="W3Schools" href="http://w3schools.com">W3Schools</a> <hr> <h2>Will not apply to:</h2> <p>Hello!</p> </body> </html>
<!DOCTYPE html> <html> <head> <style> [title=W3Schools] { border:5px solid green; } </style> </head> <body> <h2>Will apply to:</h2> <img title="W3Schools" src="w3schools_logo.gif" width="270" height="50" /> <br> <a title="W3Schools" href="http://w3schools.com">W3Schools</a> <hr> <h2>Will not apply to:</h2> <p title="greeting">Hi!</p> <a class="W3Schools" href="http://w3schools.com">W3Schools</a> </body> </html>
p[lang] - Selects all paragraph elements with a lang attribute. p[lang="fr"] - Selects all paragraph elements whose lang attribute has a value of exactly "fr". p[lang~="fr"] - Selects all paragraph elements whose lang attribute contains the word "fr". p[lang|="en"] - Selects all paragraph elements whose lang attribute contains values that are exactly "en", or begin with "en-"
<!DOCTYPE html> <html> <head> <style> [lang|=en] { color:blue; } </style> </head> <body> <h2>Will apply to:</h2> <p lang="en">Hello!</p> <p lang="en-us">Hi!</p> <p lang="en-gb">Ello!</p> <hr> <h2>Will not apply to:</h2> <p lang="us">Hi!</p> <p lang="no">Hei!</p> </body> </html>
Grouping Selectors:
 You can apply a style to many selectors if you like. Just separate the selectors with a comma as given in the following example:  h1, h2, h3 {  color: #36C;  font-weight: normal;  letter-spacing: .4em;  margin-bottom: 1em;  text-transform: lowercase;  }  This define style rule will be applicable to h1, h2 and h3 element as well
Following is the example of embed CSS based on above syntax: <head> <style type="text/css" media="all"> h1{ color: #36C; } </style> </head>
Example: Following is the example of inline CSS based on above syntax: <h1 style ="color:#36C;"> This is inline CSS </h1>
What is MIME?
 MIME (Multi-Purpose Internet Mail Extensions) is an extension of the original Internet e-mail protocol that lets people use the protocol to exchange different kinds of data files on the Internet: audio, video, images, application programs, and other kinds, as well as the ASCII text handled in the original protocol, the Simple Mail Transport Protocol (SMTP).  In 1991, Nathan Borenstein of Bellcore proposed to the IETF that SMTP be extended so that Internet (but mainly Web) clients and servers could recognize and handle other kinds of data than ASCII text. As a result, new file types were added to "mail" as a supported Internet Protocol file type.
Servers insert the MIME header at the beginning of any Web transmission. Clients use this header to select an appropriate "player" application for the type of data the header indicates. Some of these players are built into the Web client or browser (for example, all browsers come with GIF and JPEG image players as well as the ability to handle HTML files); other players may need to be downloaded.
Consider a simple style sheet file with a name mystyle.css having the following rules: h1, h2, h3 { color: #36C; font-weight: normal; letter-spacing: .4em; margin-bottom: 1em; text-transform: lowercase; } Now you can include this file mystyle.css in any HTML document as follows: <head> <link type="text/css" href="mystyle.css" media="all" /> </head>
Example: Following is the example showing you how to import a style sheet file into HTML document: <head> @import "mystyle.css"; </head>
CSS Comments:
 Many times you may need to put additional comments in your style sheet blocks. So it is very easy to comment any part in style sheet. You simple put your comments inside /*.....this is a comment in style sheet.....*/.  You can use /* ....*/ to comment multi-line blocks in similar way you do in C and C++ programming languages
CSS - Colors
<html> <head> <title>Practice CSS background-image property</title> <style type="text/css"> <!-table { background-image:url(/images/pattern1.gif); height:300px; } --> </style> </head> <body> <table> <tr> <td> This table has background image set. </td> </tr> </table> </body> </html>
<html> <head> <title>Practice CSS background-repeat property</title> <style type="text/css"> <!-table { background-image:url(/images/pattern1.gif); background-repeat: repeat; height:300px; } --> </style> </head> <body> <table> <tr> <td> This table has background image which repeats multiple times. </td> </tr> </table> </body> </html>
<table style="backgroundimage:url(/images/pattern1.gif); backgroundrepeat: repeat-y;"> <tr><td> This table has background image set which will repeat vertically. </td></tr> </table>
Following is the example which demonstrates how to repeat the background image horizontally. <table style="backgroundimage:url(/images/pattern1.gif); backgroundrepeat: repeat-x;"> <tr><td> This table has background image set which will repeat horizontally. </td></tr> </table>
<html> <head> <title>Practice CSS background-position property</title> <style type="text/css"> <!-table { background-image:url(/images/pattern1.gif); background-position:100px 200px; background-repeat:no-repeat; height:300px; } --> </style> </head> <body> <table> <tr> <td> This table has background image positioned 100 pixels away from the left and 200 pixels from the top. </td> </tr> </table> </body> </html>
<p style="background-image:url(/images/pattern1.gif); background-attachment:scroll;"> This parapgraph has scrolling background image. </p>
Shorthand property :
 You can use the font property to set all the font properties at once. For example:  <p style="font:italic small-caps bold 15px georgia;"> Applying all the properties on the text at once. </p>  This will produce following result:  APPLYING ALL THE PROPERTIES ON THE TEXT AT ONCE.
You can set following text properties of an element: The color property is used to set the color of a text. The direction property is used to set the text direction. The letter-spacing property is used to add or subtract space between the letters that make up a word. The word-spacing property is used to add or subtract space between the words of a sentence. The text-indent property is used to indent the text of a paragraph. The text-align property is used to align the text of a document. The text-decoration property is used to underline, overline, and strikethrough text. The text-transform property is used to capitalize text or convert text to uppercase or lowercase letters. The white-space property is used to control the flow and formatting of text. The text-shadow property is used to set the text shadow around a text.
Set the text color: Following is the example which demonstrates how to set the text color. Possible value could be any color name in any valid format. <p style="color:red;"> This text will be written in red. </p>
You can set following image properties using CSS. The border property is used to set the width of an image border. The height property is used to set the height of an image. The width property is used to set the width of an image. The -moz-opacity property is used to set the opacity of an image.
This tutorial will teach you how to set different properties of a hyper link using CSS. You can set following properties of a hyper link: The :link Signifies unvisited hyperlinks. The :visited Signifies visited hyperlinks. The :hover Signifies an element that currently has the user's mouse pointer hovering over it. The :active Signifies an element on which the user is currently clicking.
Remember a:hover MUST come after a:link and a:visited in the CSS definition in order to be effective. Also, a:active MUST come after a:hover in the CSS definition as follows. <style type="text/css"> a:link {color: #000000} a:visited {color: #006600} a:hover {color: #FFCC00} a:active {color: #FF00CC} </style>
Change the color of links when mouse is over: Following is the example which demonstrates how to change the color of links when we bring a mouse pointer over that link. Possible value could be any color name in any valid format. <style type="text/css"> a:hover {color: #FFCC00} </style> <a href="/html/index.htm">Bring Mouse Here</a> This will produce following link. Now you bring your mouse over this link and you will see that it changes its color to yellow.
Change the color of active links: Following is the example which demonstrates how to change the color of active links. Possible value could be any color name in any valid format. <style type="text/css"> a:active {color: #FF00CC} </style> <a href="/html/index.htm"> Click This Link</a> This will produce following link. This will change it color to pink when user clicks it.
CSS Margin
 The CSS margin properties define the space around elements.  Margin  The margin clears an area around an element (outside the border). The margin does not have a background color, and is completely transparent.  The top, right, bottom, and left margin can be changed independently using separate properties. A shorthand margin property can also be used, to change all margins at once.
<!DOCTYPE html> <html> <head> <style> p { background-color:yellow; } p.margin { margin-top:100px; margin-bottom:100px; margin-right:50px; margin-left:50px; } </style> </head> <body> <p>This is a paragraph with no specified margins.</p> <p class="margin">This is a paragraph with specified margins.</p> </body> </html>
 The margin property can have from one to four values.  margin:25px 50px 75px 100px;
    top margin is 25px right margin is 50px bottom margin is 75px left margin is 100px
  margin:25px 50px;
 top and bottom margins are 25px  right and left margins are 50px
  margin:25px;
 all four margins are 25px
CSS Border
 CSS Border Properties  The CSS border properties allow you to specify the style and color of an element's border.  Border Style  The border-style property specifies what kind of border to display.
border-style values:
<!DOCTYPE html> <html> <head> <style> p.none {border-style:none;} p.dotted {border-style:dotted;} p.dashed {border-style:dashed;} p.solid {border-style:solid;} p.double {border-style:double;} p.groove {border-style:groove;} p.ridge {border-style:ridge;} p.inset {border-style:inset;} p.outset {border-style:outset;} p.hidden {border-style:hidden;} </style> </head> <body> <p class="none">No border.</p> <p class="dotted">A dotted border.</p> <p class="dashed">A dashed border.</p> <p class="solid">A solid border.</p> <p class="double">A double border.</p> <p class="groove">A groove border.</p> <p class="ridge">A ridge border.</p> <p class="inset">An inset border.</p> <p class="outset">An outset border.</p> <p class="hidden">A hidden border.</p> </body> </html>
Border Width
 The border-width property is used to set the width of the border.  The width is set in pixels, or by using one of the three pre-defined values: thin, medium, or thick.  Note: The "border-width" property does not work if it is used alone. Use the "border-style" property to set the borders first.
<!DOCTYPE html> <html> <head> <style> p.one { border-style:solid; border-width:5px; } p.two { border-style:solid; border-width:medium; } p.three { border-style:solid; border-width:1px; } </style> </head> <body> <p class="one">Some text.</p> <p class="two">Some text.</p> <p class="three">Some text.</p> <p><b>Note:</b> The "border-width" property does not work if it is used alone. Use the "border-style" property to set the borders first.</p> </body> </html>
Border Color
 The border-color property is used to set the color of the border. The color can be set by:  name - specify a color name, like "red"  RGB - specify a RGB value, like "rgb(255,0,0)"  Hex - specify a hex value, like "#ff0000"  You can also set the border color to "transparent".  Note: The "border-color" property does not work if it is used alone. Use the "border-style" property to set the borders first.
<!DOCTYPE html> <html> <head> <style> p.one { border-style:solid; border-color:red; } p.two { border-style:solid; border-color:#98bf21; } </style> </head> <body> <p class="one">A solid red border</p> <p class="two">A solid green border</p> <p><b>Note:</b> The "border-color" property does not work if it is used alone. Use the "borderstyle" property to set the borders first.</p> </body> </html>
<!DOCTYPE html> <html> <head> <style> p { border-top-style:dotted; border-right-style:solid; border-bottom-style:dotted; border-left-style:solid; } </style> </head> <body> <p>2 different border styles.</p> </body> </html>
 border-style:dotted solid;
 top and bottom borders are dotted  right and left borders are solid
border-style:dotted;
 all four borders are dotted
The border-style property is used in the example above. However, it also works with border-width and border-color.
<!DOCTYPE html> <html> <head> <style> p { border:5px solid red; } </style> </head> <body> <p>This is some text in a paragraph.</p> </body> </html>
<html> <head> <style> p { border:1px solid red; outline-style:dotted; outline-color:#00ff00; } </style> </head> <body> <p><b>Note:</b> IE8 supports the outline properties only if a !DOCTYPE is specified.</p> </body> </html>
<!DOCTYPE html> <html> <head> <style> p.one { border:1px solid red; outline-style:solid; outline-width:thin; } p.two { border:1px solid red; outline-style:dotted; outline-width:3px; } </style> </head> <body>
<p class="one">This is some text in a paragraph.</p> <p class="two">This is some text in a paragraph.</p>
<p><b>Note:</b> IE8 supports the outline properties only if a !DOCTYPE is specified.</p> </body> </html>
The padding property allows you to specify how much space should appear between the content of an element and its border: There are following five CSS properties which can be used to control lists: The padding-bottom Specifies the bottom padding of an element. The padding-top Specifies the top padding of an element. The padding-left Specifies the left padding of an element. The padding-right Specifies the right padding of an element. The padding Serves as shorthand for the preceding properties.
The padding shorthand property sets all the padding properties in one declaration. This property can have from one to four values. Examples: padding:10px 5px 15px 20px;
    top padding is 10px right padding is 5px bottom padding is 15px left padding is 20px
  padding:10px 5px;
 top and bottom padding are 10px  right and left padding are 5px
 padding:10px;
 all four paddings are 10px
<!DOCTYPE html> <html> <head> <style> p.padding {padding-bottom:2cm;} p.padding2 {padding-bottom:50%;} </style> </head> <body> <p>This is a text with no bottom padding. This is a text with no bottom padding. This is a text with no bottom padding.</p> <p class="padding">This text has a bottom padding of 2 cm. This text has a bottom padding of 2 cm. This text has a bottom padding of 2 cm.</p> <p class="padding2">This text has a bottom padding of 50%. This text has a bottom padding of 50%. This text has a bottom padding of 50%.</p> </body> </html>
<!DOCTYPE html> <html> <head> <style> p.padding {padding-right:2cm;} p.padding2 {padding-right:50%;} </style> </head>
<body> <p>This is a text with no right padding. This is a text with no right padding. This is a text with no right padding.</p> <p class="padding">This text has a right padding of 2 cm. This text has a right padding of 2 cm. This text has a right padding of 2 cm.</p> <p class="padding2">This text has a right padding of 50%. This text has a right padding of 50%. This text has a right padding of 50%.</p> </body> </html>
<!DOCTYPE html> <html> <head> <style> h1.visible {visibility:visible} h1.hidden {visibility:hidden} </style> </head> <body> <h1 class="visible">This is a visible heading</h1> <h1 class="hidden">This is an invisible heading</h1> <p>Notice that the invisible heading still takes up space.</p> </body> </html>