Complete HTML XML JS CSS WT-Course-Material
Complete HTML XML JS CSS WT-Course-Material
Unit-I
HTML COMMON TAGS
What is an HTML File?
<html>
<head>
<title>Title of page</title>
</head>
<body>
Hello World! This is my first homepage. <b>This text is bold</b>
</body>
</html>
Start your Internet browser. Select "Open" (or "Open Page") in the File menu of your
browser. A dialog box will appear. Select "Browse" (or "Choose File") and locate the HTML file
you just created - "mypage.html" - select it and click "Open". Now you should see an address in
the dialog box, for example "C:\MyDocuments\webdesign\mypage.html". Click OK, and the
browser will display the page.
Example Explained
The first tag in your HTML document is <html>. This tag tells your browser that this is
the start of an HTML document. The last tag in your document is </html>. This tag tells your
browser that this is the end of the HTML document.
The text between the <head> tag and the </head> tag is header information. Header
information is not displayed in the browser window. The text between the <title> tags is the title
of your document. The title is displayed in your browser's caption. The text between the <body>
tags is the text that will be displayed in your browser. The text between the <b> and </b> tags
will be displayed in a bold font.
C -1-
Web Technologies Unit-I
HTML ELEMENTS
HTML documents are text files made up of HTML elements. HTML elements are
defined using HTML tags.
HTML Tags
The purpose of the <b> tag is to define an HTML element that should be displayed as bold.
Tag Attributes
Tags can have attributes. Attributes can provide additional information about the HTML
elements on your page.
This tag defines the body element of your HTML page: <body>. With an added bgcolor
attribute, you can tell the browser that the background color of your page should be red, like this:
<body bgcolor="red">
This tag defines an HTML table: <table>. With an added border attribute, you can tell the
browser that the table should have no borders: <table border="0">. Attributes always come in
name/value pairs like this: name="value". Attributes are always added to the start tag of an
HTML element.
1. HEADINGS
Headings are defined with the <h1> to <h6> tags. <h1> defines the largest heading. <h6>
defines the smallest heading.
<h1>This is a heading</h1>
<h2>This is a heading</h2>
<h3>This is a heading</h3>
<h4>This is a heading</h4>
<h5>This is a heading</h5>
<h6>This is a heading</h6>
C -2-
Web Technologies Unit-I
HTML automatically adds an extra blank line before and after a heading.
2. PARAGRAPHS
<p>This is a paragraph</p>
<p>This is another paragraph</p>
HTML automatically adds an extra blank line before and after a paragraph.
3. LINE BREAKS
The <br> tag is used when you want to end a line, but don't want to start a new paragraph. The
<br> tag forces a line break wherever you place it.
4. Comments in HTML
The comment tag is used to insert a comment in the HTML source code. A comment will be
ignored by the browser. You can use comments to explain your code, which can help you when
you edit the source code at a later date.
Note that you need an exclamation point after the opening bracket, but not before the closing
bracket.
C -3-
Web Technologies Unit-I
Example
Source Output
<i>Italic text</i><br /> Italic text
<b>Bold text</b><br /> Bold text
<em>Emphasized text</em><br> Emphasized text
<strong>Strong text</strong><br> Strong text
What is the difference between <i> & <em> and <b> & <strong>, <b> and <i> will both
become deprecated tags. Using <strong> and <em> are the tags that will be cross-browser
compatible as browsers move forward to embrace the new standards in HTML (e.g., XHTML)
2. HTML Links
HTML uses a hyperlink to link to another document on the Web. HTML uses the <a>
(anchor) tag to create a link to another document. An anchor can point to any resource on the
Web: an HTML page, an image, a sound file, a movie, etc.
The <a> tag is used to create an anchor to link from, the href attribute is used to address the
document to link to, and the words between the open and close of the anchor tag will be
displayed as a hyperlink.
<a href="">Google</a>
C -4-
Web Technologies Unit-I
<a name="label">Text to be displayed</a>
The name attribute is used to create a named anchor. The name of the anchor can be any text you
care to use.
The line below defines a named anchor:
<a name="tips">Useful Tips Section</a>
You should notice that a named anchor is not displayed in a special way. To link directly to the
"tips" section, add a # sign and the name of the anchor to the end of a URL, like this:
<a href="> Jump to the Useful Tips Section</a>
HTML LISTS
HTML supports ordered, unordered and definition lists.
1. Unordered Lists
An unordered list is a list of items. The list items are marked with bullets (typically small
black circles).
An unordered list starts with the <ul> tag. Each list item starts with the <li> tag.
<ul>
<li>Coffee</li>
<li>Milk</li>
</ul>
Here is how it looks in a browser:
Coffee
Milk
Inside a list item you can put paragraphs, line breaks, images, links, other lists, etc.
2. Ordered Lists
An ordered list is also a list of items. The list items are marked with numbers.
An ordered list starts with the <ol> tag. Each list item starts with the <li> tag.
<ol>
<li>Coffee</li>
<li>Milk</li>
</ol>
Here is how it looks in a browser:
1. Coffee
2. Milk
Inside a list item you can put paragraphs, line breaks, images, links, other lists, etc.
C -5-
Web Technologies Unit-I
HTML TABLE
Tables are defined with the <table> tag.
A table is divided into rows (with the <tr> tag), and each row is divided into data cells (with the
<td> tag). td stands for "table data," and holds the content of a data cell. A <td> tag can contain
text, links, images, lists, forms, other tables, etc.
Table Example
<table border="1">
<tr>
<td>row 1, cell 1</td>
<td>row 1, cell 2</td>
</tr>
<tr>
<td>row 2, cell 1</td>
<td>row 2, cell 2</td>
</tr>
</table>
If you do not specify a border attribute, the table will be displayed without borders. Sometimes
this can be useful, but most of the time, we want the borders to show.
<table border="1">
<tr>
<td>Row 1, cell 1</td>
<td>Row 1, cell 2</td>
</tr>
</table>
C -6-
Web Technologies Unit-I
Header information in a table are defined with the <th> tag. All major browsers display the text
in the <th> element as bold and centered.
<table border="1">
<tr>
<th>Header 1</th>
<th>Header 2</th>
</tr>
<tr>
<td>row 1, cell 1</td>
<td>row 1, cell 2</td>
</tr>
<tr>
<td>row 2, cell 1</td>
<td>row 2, cell 2</td>
</tr>
</table>
Header 1 Header 2
C -7-
Web Technologies Unit-I
rules none Not supported in HTML5. Specifies which parts of the inside
groups borders that should be visible
rows
cols
all
summary text Not supported in HTML5. Specifies a summary of the
content of a table
width pixels Not supported in HTML5. Specifies the width of a table
%
Example
<table border="1">
<tr>
<th>Month</th>
<th>Savings</th>
</tr>
<tr>
C -8-
Web Technologies Unit-I
<td>January</td>
<td>$100</td>
</tr>
</table>
HTML IMAGES
With HTML you can display images in a document.
In HTML, images are defined with the <img> tag. To display an image on a page, you
need to use the src attribute. Src stands for "source". The value of the src attribute is the URL of
the image you want to display on your page.
The syntax of defining an image: <img src="url">
The URL points to the location where the image is stored. An image named "boat.gif"
located in the directory "images" on "www.w3schools.com" has the URL:
http://www.w3schools.com/images/boat.gif. The browser puts the image where the image tag
occurs in the document. If you put an image tag between two paragraphs, the browser shows the
first paragraph, then the image, and then the second paragraph.
The alt attribute is used to define an "alternate text" for an image. The value of the alt attribute is
an author-defined text:
HTML BACKGROUNDS
A good background can make a Web site look really great.
Backgrounds
The <body> tag has two attributes where you can specify backgrounds. The background can be a
color or an image.
1. Bgcolor
The bgcolor attribute specifies a background-color for an HTML page. The value of this attribute
can be a hexadecimal number, an RGB value, or a color name:
<body bgcolor="#000000">
<body bgcolor="rgb(0,0,0)">
<body bgcolor="black">
C -9-
Web Technologies Unit-I
The lines above all set the background-color to black.
2. Background
The background attribute specifies a background-image for an HTML page. The value of this
attribute is the URL of the image you want to use. If the image is smaller than the browser
window, the image will repeat itself until it fills the entire browser window.
<body background="images/cloudswirl.jpg">
<body background="">
FORMS
Forms can be used to collect information. Sophisticated forms may be linked to a
database to store the information, but this is beyond the scope of the article. This article will
show you how to create a form that emails you the information.
Here is a very basic email form:
<form action="mailto:support@pixelmill.com" method="post">
Name:<br>
<input type="text" name="name" size="20"><br>
Email:<br>
<input type="text" name="email" size="20"><br>
Comment:<br>
<textarea cols="20" rows="5"></textarea><br>
<input type="submit" value="Submit"> <input type="reset" value="Reset">
</form>
And here's what it looks like:
Name:
Email:
Comment:
Submit Reset
Notice that the "input" tag was used for the text fields as well as the buttons! The "input" tag is
the tag you will use most often in forms. Here are different forms of the input tag:
type="text"
type="password" (asterisks when you type)
type="checkbox"
type="radio"
Submit Query
type="submit" (You can change the text on the button.)
C - 10
Web Technologies Unit-I
Below you will find a table of the various form elements and how you can use them.
FORM – attributes
action This attribute usually has a link to a web page that contains code which
="[url]" processes the form. In our example above, we use "mailto" to tell the form to
send the information as an email.
method This attribute specifies how the information is sent. With the "get" method, all
="get" the information is sent in one long URL string. With the "post" method, all the
="post" information is sent but is "invisible" to the user.
name When creating complex forms and using scripting, you may need to specify the
="[name of name of the form. The name should be unique - that is, you shouldn't have other
form]" forms on the page with the same form name.
INPUT – attributes
type The "type" attribute allows you to specify what type of form element you want
="text" to use. As you can see, the "input" element can have many different forms - see
="password" above for examples.
="checkbox"
="radio"
="submit"
="reset"
="hidden"
="button"
checked This attribute does not have any values. When you put this attribute into the tag
for "radio" or "checkbox," they will be selected.
src Use this attribute when you have an "image" to specify the location of the image.
="[url]"
TEXTAREA - attributes
This form element is the multi-line text box that you often seen for "comments." The opening
and closing tag surround the text that will be initially displayed.
name This attribute must be set to a unique name so you know how to refer to the form
="[referring element.
name]"
rows This attribute allows you to set the number of rows for the text area.
="[number]"
cols This attribute allows you to set the number of columns for the text area.
="[number]"
C - 11
Web Technologies Unit-I
SELECT - attributes
The SELECT tag allows you to create "select boxes" or "drop down menus." It is the
"outer" element, used with the OPTION tag. (See the example link below)
name This attribute must be set to a unique name so you know how to refer to the form
="[referring element.
name]"
size This attribute allows you to set how many rows are visible.
="[number]"
multiple This attribute does not have any "values." When you set this attribute, it allows
the user to select more than one option.
OPTION - attributes
The OPTION tag is used with the SELECT tag to define the different options in the select
box or dropdown menu. The opening and closing tag surround the text that will be displayed.
value This attribute must be set to a unique name so you know how to refer to the form
="[value]" element. It will probably be an abbreviated version of the text that is displayed.
selected This attribute does not have any "values." When you set this attribute, it marks
this option as being "preselected."
Putting it all together...
Here's a sample page using this code below:
<form>
Enter your Name: <input type="text" width="20" size="20">
<p>Favorite Color:<br>
<input type="checkbox" checked value="red" name="colors"> Red<br>
<input type="checkbox" value="blue" name="colors"> Blue</p>
<p>Gender:<br>
<input type="radio" checked value="male" name="gender">Male<br>
<input type="radio" value="female" name="gender">Female</p>
<p>Address:<br>
<textarea rows="5" cols="20">Please enter your permanent
address here.</textarea></p>
Country:<br>
<select name="country">
<option value="usa" selected>USA</option>
<option value="uk">United Kingdom</option>
<option value="canada">Canada</option>
</select>
C - 12
Web Technologies Unit-I
CSS
Introduction to CSS:
CSS stands for Cascading Style Sheets. CSS describes how HTML elements are to be
displayed on screen, paper, or in other media. CSS saves a lot of work. It can control the layout
of multiple web pages all at once. External style sheets are stored in “.css” files. CSS is used to
define styles for your web pages, including the design, layout and variations in display for
different devices and screen sizes.
Types of CSS:
There are three types of CSS available. They are:
1) Inline CSS
2) Internal CSS
3) External CSS
1. Inline CSS:
If the styles are mentioned along with the tag then this type of CSS is known as inline CSS.
Example:
<p style=”text-align: justify; background-color: red”>Hi this is the Inline CSS. </p>
2. Internal CSS:
For internal CSS, we write all the desired “styles” for the “selectors” along with the
properties and values in the “head” section. And in the body section then newly defied
selector tags are used with the actual contents.
Example:
<html>
3. External
<head>CSS:
Sometimes we need to apply particular style to more than one web page; in such cases
<style type=
external CSS can
“text/css”> p be used. The main idea in this type of CSS is that the desired styles can be
{
written in one “.css” file. And this file can be called in our web pages to apply the styles.
text-align: justify;
background-color:
red;
}
</style>
</head>
<body>
<p>This is Internal CSS.</p>
</body>
</html>
C - 13
Web Technologies Unit-I
Example:
<html>
CSS Selectors:
<head>
CSS selectors are used to "find" (or select) HTML elements based on their element name,
<link rel = “stylesheet”
id, class, attribute, and more. type = “text/css” href = “external.css”>
</head>
<body>Selector:
The element
<p>Thisselector
The element is Internal CSS.</p>
selects elements based on the element name. You can select all <p>
</body>
elements on a page like this (in this case, all <p> elements will be center-aligned, with a red text
color):</html>
external.css:
Example:
p{ p
{
text-align: center;
text-align:
color: red; justify;
} background-color:
red;
The id} Selector:
The id selector uses the id attribute of an HTML element to select a specific element. The id of
an element should be unique within a page, so the id selector is used to select one unique
element! To select an element with a specific id, write a hash (#) character, followed by the id of
the element. The style rule below will be applied to the HTML element with id="para1":
Example:
#para1 {
text-align: center;
color: red;
}
C - 14
Web Technologies Unit-I
The class Selector:
The class selector selects elements with a specific class attribute. To select elements with a
specific class, write a period (.) character, followed by the name of the class. In the example
below, all HTML elements with class="center" will be red and center-aligned:
Example:
.center {
text-align: center;
color: red;
}
You can also specify that only specific HTML elements should be affected by a class. In the
example below, only <p> elements with class="center" will be center-aligned:
Example:
p.center {
text-align: center;
color: red;
}
HTML elements can also refer to more than one class. In the example below, the <p> element
will be styled according to class="center" and to class="large":
Example:
<p class="center large">This paragraph refers to two classes.</p>
Now, what we want to do is to have the header take up the whole of the top row, with the menu
and content underneath, arranged side by side. To do this we would use the following CSS (the
header section doesn't require any CSS):
#menu {
float: left;
}
C - 15
Web Technologies Unit-I
#content {
float: left;
}
#menu {
float: left;
width: 10em;
}
Widths can be specified in pixels, ems or as a percentage of the total page width.
The CSS clear property
We have seen how we can position HTML elements next to each other using CSS, but
sometimes we might want an element to appear beneath other elements. We can easily force an
element to sit below another using the clear property. When using clear, we can tell an element
to either clear those elements which are floated left, those which are floated right, or both:
Example:
#divname {
clear: left / right / both;
}
Changing Background:
The CSS background properties are used to define the background effects for elements.
CSS background properties:
background-color
background-image
background-repeat
background-attachment
background-position
Background Color
The background-color property specifies the background color of an element. The
background color of a page is set like this:
Example
body {
background-color: lightblue;
}
With CSS, a color is most often specified by:
A valid color name - like "red"
A HEX value - like "#ff0000"
An RGB value - like "rgb(255,0,0)"
C - 16
Web Technologies Unit-I
Background Image:
The background-image property specifies an image to use as the background of an
element. By default, the image is repeated so it covers the entire element. The background image
for a page can be set like this:
Example:
body {
background-image: url("paper.gif");
}
C - 17
Web Technologies Unit-I
Background Image - Fixed position
To specify that the background image should be fixed (will not scroll with the rest of the
page), use the background-attachment property:
Example:
body {
background-image: url("img_tree.png");
background-repeat: no-repeat;
background-position: right top;
background-attachment: fixed;
}
The border-width property specifies the width of the four borders. The width can be set as a
specific size (in px, pt, cm, em, etc) or by using one of the three pre-defined values: thin,
medium, or thick. The border-width property can have from one to four values (for the top
border, right border, bottom border, and the left border).
C - 18
Web Technologies Unit-I
Example
p.one {
border-style: solid;
border-width: 5px;
}
p.two {
border-style: solid;
border-width: medium;
}
p.three {
border-style: solid;
border-width: 2px 10px 4px 20px;
}
The border-color property is used to set the color of the four borders. The color can be set by:
name - specify a color name, like "red"
Hex - specify a hex value, like "#ff0000"
RGB - specify a RGB value, like "rgb(255,0,0)"
transparent
The border-color property can have from one to four values (for the top border, right
border, bottom border, and the left border). If border-color is not set, it inherits the color of
the element.
Example
p.one {
border-style: solid;
border-color: red;
}
p.two {
border-style: solid;
border-color: green;
}
p.three {
border-style: solid;
border-color: red green blue yellow;
}
C - 19
Web Technologies Unit-I
XML
WHAT IS XML?
XML stands for extensible markup language. XML is a markup language much like
HTML. XML was designed to carry data, not to display data. XML tags are not predefined. You
must define your own tags. XML is designed to be self-descriptive. XML is a w3c
recommendation.
THE DIFFERENCE BETWEEN XML AND HTML:
XML is not a replacement for HTML. XML and HTML were designed with different
goals. XML was designed to transport and store data, with focus on what data is. HTML was
designed to display data, with focus on how data looks. HTML is about displaying information,
while XML is about carrying information.
XML does not do anything: May be it is a little hard to understand, but XML does not do
anything. XML was created to structure, store, and transport information. The following example
is a note to chythu, from ravi, stored as XML:
<note>
<to> chythu </to>
<from> ravi </from>
<heading>reminder</heading>
<body>don't forget me this weekend!</body>
</note>
The note above is quite self-descriptive. It has sender and receiver information, it also has
a heading and a message body. But still, this XML document does not do anything. It is just
information wrapped in tags. Someone must write a piece of software to send, receive or display
it.
With XML you invent your own tags: The tags in the example above (like <to> and <from>)
are not defined in any XML standard. These tags are "invented" by the author of the XML
document. That is because the XML language has no predefined tags. The tags used in HTML
are predefined. HTML documents can only use tags defined in the HTML standard (like <p>,
<h1>, etc.). XML allows the author to define his/her own tags and his/her own document
structure. XML is not a replacement for HTML; XML is a complement to HTML. It is important
to understand that XML is not a replacement for HTML. In most web applications, XML is used
to transport data, while HTML is used to format and display the data.
My best description of XML is this: XML is a software- and hardware-independent tool for
carrying information. XML is a W3C recommendation. XML became a W3C recommendation
February 10, 1998. XML is everywhere. XML is now as important for the web as HTML was to
the foundation of the web. XML is the most common tool for data transmissions between all
sorts of applications.
XML separates data from HTML: If you need to display dynamic data in your HTML
document, it will take a lot of work to edit the HTML each time the data changes. With XML,
data can be stored in separate XML files. This way you can concentrate on using HTML for
layout and display, and be sure that changes in the underlying data will not require any changes
to the HTML. With a few lines of JavaScript code, you can read an external XML file and update
the data content of your web page.
Unique Features of XML:
a) Sharing of data: In the real world, computer systems and databases contain data in
incompatible formats. XML data is stored in plain text format. This provides a software-
C - 20
Web Technologies Unit-I
and hardware-independent way of storing data. This makes it much easier to create data
that can be shared by different applications.
b) Transporting data: One of the most time-consuming challenges for developers is to
exchange data between incompatible systems over the internet. Exchanging data as XML
greatly reduces this complexity, since the data can be read by different incompatible
applications.
c) Change of platform: Upgrading to new systems (hardware or software platforms), is
always time consuming. Large amounts of data must be converted and incompatible data
is often lost. XML data is stored in text format. This makes it easier to expand or upgrade
to new operating systems, new applications, or new browsers, without losing data.
d) Availability of data: Different applications can access your data, not only in HTML
pages, but also from XML data sources. With XML, your data can be available to all
kinds of "reading machines" (handheld computers, voice machines, news feeds, etc), and
make it more available for blind people, or people with other disabilities.
Structure of XML:
XML documents form a tree structure that starts at "the root" and branches to "the
leaves". An example of XML document is shown below. XML documents use a self-describing
and simple syntax:
<?XML version="1.0" encoding="iso-8859-1"?>
<note>
<to> Chythu </to>
<from> Ravi </from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>
The first line is the XML declaration. It defines the XML version (1.0) and the encoding used
(ISO-8859-1 = latin-1/west European character set). The next line describes the root element of
the document (like saying: "This document is a note"):
<note>
The next 4 lines describe 4 child elements of the root (to, from, heading, and body):
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
And finally the last line defines the end of the root element:
</note>
You can assume, from this example, that the XML document contains a note to Tove from Jani.
Don't you agree that XML is pretty self-descriptive? XML documents form a tree structure XML
documents must contain a root element. This element is "the parent" of all other elements. The
elements in an XML document form a document tree. The tree starts at the root and branches to
the lowest level of the tree. All elements can have sub elements (child elements):
<root>
<child>
<subchild>....</subchild>
</child>
C - 21
Web Technologies Unit-I
</root>
The terms parent, child, and sibling are used to describe the relationships between elements.
Parent elements have children. Children on the same level are called siblings (brothers or sisters).
All elements can have text content and attributes (just like in html).
Example:
<bookstore>
<book category="cooking">
<title lang="en">Everyday Italian</title>
<author>giada de laurentiis</author>
<year>2005</year>
<price>30.00</price>
</book>
<book category="children">
<title lang="en">harry potter</title>
<author>j k. rowling</author>
<year>2005</year>
<price>29.99</price>
</book>
<book category="web">
<title lang="en">learning XML</title>
<author>erik t. ray</author>
<year>2003</year>
<price>39.95</price>
</book>
</bookstore>
The root element in the example is <bookstore>. All <book> elements in the document
are contained within <bookstore>. The <book> element has 4 children: <title>, <author>,
<year>, and <price>.
XML syntax rules:
The syntax rules of XML are very simple and logical. The rules are easy to learn, and easy to
use. All XML elements must have a closing tag. In HTML, Elements do not have to have a
closing tag:
<p>this is a paragraph
<p>this is another paragraph
In XML, it is illegal to omit the closing tag. All elements must have a closing tag:
<p>this is a paragraph</p>
<p>this is another paragraph</p>
Note: You might have noticed from the previous example that the XML declaration did not have
a closing tag. This is not an error. The declaration is not a part of the XML document itself, and
it has no closing tag.
XML tags are case sensitive: The tag <letter> is different from the tag <LETTER>. Opening
and closing tags must be written with the same case:
<Message>This is incorrect</MESSAGE>
<Message>This is correct</Message>
Note: "Opening and closing tags" are often referred to as "start and end tags". Use whatever you
prefer. It is exactly the same thing.
C - 22
Web Technologies Unit-I
XML elements must be properly nested: In html, you might see improperly nested elements:
<b><i>this text is bold and italic</b></i> <!--This is wrong-->
In XML, all elements must be properly nested within each other:
<b><i>this text is bold and italic</i></b>
In the example above, "properly nested" simply means that since the <i> element is opened
inside the <b> element, it must be closed inside the <b> element.
XML documents must have a root element: XML documents must contain one element that is
the parent of all other elements. This element is called the root element.
<root>
<child>
<subchild>....</subchild>
</child>
</root>
XML attribute values must be quoted: XML elements can have attributes in name/value pairs
just like in html. In XML, the attribute values must always be quoted. Study the two XML
documents below. The first one is incorrect, the second is correct:
<note date=12/11/2007>
<to>tove</to>
<from>jani</from>
</note>
<note date="12/11/2007">
<to>tove</to>
<from>jani</from>
</note>
The error in the first document is that the date attribute in the note element is not quoted.
Entity References: Some characters have a special meaning in XML. If you place a character
like "<" inside an XML element, it will generate an error because the parser interprets it as the
start of a new element. This will generate an XML error:
<message>if salary < 1000 then</message>
To avoid this error, replace the "<" character with an entity reference:
<message>if salary < 1000 then</message>
There are 5 predefined entity references in XML:
< < less than
> > greater than
& & ampersand
' ' apostrophe
" " quotation mark
Note: only the characters "<" and "&" are strictly illegal in XML. the greater than character is
legal, but it is a good habit to replace it.
Comments in XML: The syntax for writing comments in XML is similar to that of html.
<!-- this is a comment -->
white-space is preserved in XML
HTML truncates multiple white-space characters to one single white-space:
HTML: hello tove
Output: hello tove
With XML, the white-space in a document is not truncated.
C - 23
Web Technologies Unit-I
XML stores new line as lf in windows applications, a new line is normally stored as a pair of
characters: carriage return (cr) and line feed (lf). In UNIX applications, a new line is normally
stored as an lf character. Macintosh applications also use an lf to store a new line. XML stores a
new line as lf.
Basic Building Blocks of XML Documents:
All XML documents are made up the following four building blocks:
i. Elements/Tags
ii. Attributes
iii. Entities
iv. Character Data
a. Parsed Character Data (PCDATA)
b. Unparsed Character Data (CDATA)
i) XML Elements/Tags:
An XML element is everything from (including) the element's start tag to (including) the
element's end tag. An element can contain: other elements text, attributes or a mix of all of the
above.
<bookstore>
<book category="children">
<title>harry potter</title>
<author>j k. rowling</author>
<year>2005</year>
<price>29.99</price>
</book>
<book category="web">
<title>learning XML</title>
<author>erik t. ray</author>
<year>2003</year>
<price>39.95</price>
</book>
</bookstore>
In the example above, <bookstore> and <book> have element contents, because they
contain other elements. <book> also has an attribute (category="children"). <title>, <author>,
<year>, and <price> have text content because they contain text.
C - 24
Web Technologies Unit-I
Make names descriptive. Names with an underscore separator are nice: <first_name>,
<last_name>.
Names should be short and simple, like this: <book_title> not like this:
<the_title_of_the_book>.
Avoid "-" characters. If you name something "first-name," some software may think you
want to subtract name from first.
Avoid "." characters. If you name something "first.name," some software may think that
"name" is a property of the object "first."
Avoid ":" characters. Colons are reserved to be used for something called namespaces
(more later).
XML documents often have a corresponding database. a good practice is to use the
naming rules of your database for the elements in the XML documents.
Non-english letters like éòá are perfectly legal in XML, but watch out for problems if
your software vendor doesn't support them.
C - 25
Web Technologies Unit-I
<img src="computer.gif">
<a href="demo.asp">
Attributes often provide information that is not a part of the data. In the example below,
the file type is irrelevant to the data, but can be important to the software that wants to
manipulate the element:
<file type="gif">computer.gif</file>
XML attributes must be quoted: Attribute values must always be quoted. Either single or
double quotes can be used. For a person's sex, the person element can be written like this:
<person sex="female">
or like this:
<person sex='female'>
If the attribute value itself contains double quotes you can use single quotes, like in this example:
<gangster name='george "shotgun" ziegler'>
or you can use character entities:
<gangster name="george "shotgun" ziegler">
C - 26
Web Technologies Unit-I
<heading>reminder</heading>
<body>don't forget me this weekend!</body>
</note>
3) An expanded date element is used in the third: (this is my favorite):
<note>
<date>
<day>10</day>
<month>01</month>
<year>2008</year>
</date>
<to>tove</to>
<from>jani</from>
<heading>reminder</heading>
<body>don't forget me this weekend!</body>
</note>
C - 27
Web Technologies Unit-I
The ID attributes above are for identifying the different notes. It is not a part of the note
itself. What I'm trying to say here is that metadata (data about data) should be stored as
attributes, and the data itself should be stored as elements.
iii) XML Entities:
An entity is the symbolic representation of some information. It references the data that
look like an abbreviation or can be found at an external location. Entities reduce the redundant
information and also allow for easier editing. The entities can be internal or external. For
example, the entity „&‟ will replace as „&‟, where ever it is found in the XML document.
iv) PCDATA:
PCDATA stands for Parsed Character Data. The text enclosed between starting and
ending tag is known as Character Data. The parser parses the PCDATA and identifies the entities
as well as markup. Markups include the tags inside the text and entities are expanded. In the case
of Parsed Character Data, the symbols „&‟, „<‟, „>‟ are represented using entities.
v) CDATA:
CDATA stands for Character Data and it is not parsed by the parser. The tags inside the
text are not considered as markup and the entities are not expanded.
Validation of XML:
There are two levels of correctness of an XML document:
1) XML with correct syntax is Well Formed XML.
2) XML validated against a DTD is Valid XML.
A Well Formed XML document is a document that conforms to the XML syntax rules like:
XML documents must have a root element.
XML elements must have a closing tag.
XML tags are case sensitive.
XML elements must be properly nested.
XML attribute values must be quoted
Example:
<?XML version="1.0" encoding="iso-8859-1"?>
<note>
<to>tove</to>
<from>jani</from>
<heading>reminder</heading>
<body>don't forget me this weekend!</body>
</note>
A Valid XML document is a “well formed” XML document, which conforms to the rules of a
document type definition (DTD).
Document Type Definition (DTD):
The purpose of a DTD is to define the structure of an XML document. It defines the
structure with a list of legal elements:
DTD Syntax:
<!DOCTYPE DOCUMENT [
<!ELEMENT ELEMENT_NAME1 (Attribute Names) Appearance of attributes>
<!ELEMENT ELEMENT_NAME2>
C - 28
Web Technologies Unit-I
<!ELEMENT ELEMENT_NAME3>
.
.
.
<!ELEMENT ELEMENT_NAMEn>
<!ATTLIST Element_name Attribute_name Attribute_type Default_value>
]>
A DTD can be declared inline inside an XML document, or as an external reference.
<!DOCTYPE note[
<!ELEMENT note (to,from,heading,body)>
<!ELEMENT to (#PCDATA)>
<!ELEMENT from (#PCDATA)>
<!ELEMENT heading (#PCDATA)>
<!ELEMENT body (#CDATA)>
]>
<note>
<to>Ravi</to>
<from>Chythanya</from>
<heading>Message</heading>
<body>Welcome to the XML with DTD</body>
</note>
The DTD above is interpreted like this:
!DOCTYPE note defines that the root element of this document is note.
!ELEMENT note defines that the note element contains four elements “to, from, heading,
body”.
!ELEMENT to defines that to element to be of the type #PCDATA.
!ELEMENT from defines that from element to be of the type #PCDATA.
!ELEMENT heading defines that heading element to be of the type #PCDATA.
!ELEMENT body defines that body element to be of the type #CDATA.
C - 29
Web Technologies Unit-I
<body>Welcome to the XML with DTD</body>
</note>
emailDTD.dtd:
<!ELEMENT note (to,from,heading,body)>
<!ELEMENT to (#PCDATA)>
<!ELEMENT from (#PCDATA)>
<!ELEMENT heading (#PCDATA)>
<!ELEMENT body (#CDATA)>
XML Schema:
W3C supports an XML-based alternative to DTD, called XML schema:
1) The XML schema is used to represent the structure of XML document. The goal or
purpose of XML schema is to define the building blocks of an XML document. These
can be used as an alternative to XML DTD. The XML schema language is called as XML
Schema Definition (XSD) language. The XML schema became the World Wide Web
Consortium (W3C) recommendation in 2001.
2) XML schema defines elements, attributes, elements having child elements, order of child
elements. It also defines fixed and default values of elements and attributes.
3) XML schema also allows the developers to use data types.
4) File extension of XML schema is “.xsd” i.e., Filename.xsd
Ex:
StudentSchema.xsd:
<?XML version=”1.0”?>
<xs:schema XMLns:xs=“http://www.w3.org/2001/XMLschema”>
<xs:element name="student">
<xs:complextype>
<xs:sequence>
<xs:element name="name" type="xs:string"/>
<xs:element name="address" type="xs:string"/>
<xs:element name="std" type="xs:string"/>
<xs:element name="marks" type="xs:string"/>
</xs:sequence>
</xs:complextype>
</xs:element>
</xs:schema>
C - 30
Web Technologies Unit-I
Various data types are that can be used to specify the data types of an elements are:
String
Date
Time
Numeric
Boolean
XML Document[stringTypeDemo.xml]:
<?xml version="1.0" encoding="iso-8859-1" ?>
<StudentName XMLns:xsi = "http://www.w3.org/2001/XMLschema-instance"
xsi:nonamespaceschemalocation = "stringType.xsd">
Ravi Chythanya
</StudentName>
XML Document[dateTypeDemo.xml]:
<?xml version="1.0" encoding="iso-8859-1" ?>
<DOB XMLns:xsi = "http://www.w3.org/2001/XMLschema-instance"
xsi:nonamespaceschemalocation = "dateType.xsd">
1988-03-01
</DOB>
C - 31
Web Technologies Unit-I
<xs:schema xmlns:xs=“ http://www.w3.org/2001/XMLschema”>
<xs:element name= “MyTime” type=“xs:time”>
</xs:schema>
XML Document[timeTypeDemo.xml]:
<?xml version="1.0" encoding="iso-8859-1" ?>
<MyTime XMLns:xsi = "http://www.w3.org/2001/XMLschema-instance"
xsi:nonamespaceschemalocation = "timeType.xsd">
01:57:03
</MyTime>
XML Document[decimalTypeDemo.xml]:
<?xml version="1.0" encoding="iso-8859-1" ?>
<Percentage XMLns:xsi = "http://www.w3.org/2001/XMLschema-instance"
xsi:nonamespaceschemalocation = "decimalType.xsd">
99.99
</Percentage>
XML Document[integerTypeDemo.xml]:
<?xml version="1.0" encoding="iso-8859-1" ?>
<Age XMLns:xsi = "http://www.w3.org/2001/XMLschema-instance"
xsi:nonamespaceschemalocation = "integerType.xsd">
30
</Age>
C - 32
Web Technologies Unit-I
<xs:element name= “Flag” type=“xs:boolean”>
</xs:schema>
XML Document[booleanTypeDemo.xml]:
<?xml version="1.0" encoding="iso-8859-1" ?>
<Flag XMLns:xsi = "http://www.w3.org/2001/XMLschema-instance"
xsi:nonamespaceschemalocation = "booleanType.xsd">
true
</Flag>
Simple Types:
XML defines the simple type which contains only text and does not contain any other element or
attributes. But the text appears for element comes along with some type. The syntax is:
<xs:element name= “element_name” type= “data_type”>
Here the type can be any built in data type:
xs:string
xs:date
xs:time
xs:integer
xs:decimal
xs:Boolean
XML Document[MonthDemo.xml]:
<?xml version="1.0" encoding="iso-8859-1" ?>
<Age xmlns:xsi = "http://www.w3.org/2001/XMLschema-instance"
xsi:nonamespaceschemalocation = "Month.xsd">
12
</Month>
Various facets that can be applied are:
length – Specifies exact number of characters.
C - 33
Web Technologies Unit-I
minLength – Specifies the minimum number of characters allowed.
maxLength – Specifies the minimum number of characters allowed.
minInclusive – Specifies lower bound for numeric values.
minExclusive – Specifies lower bound for numeric values.
maxInclusive – Specifies upper bound for numeric values.
maxExclusive – Specifies upper bound for numeric values.
enumeration – A list of acceptable values can be defined.
pattern – specifies exact sequence of characters that are acceptable.
totalDigits – Specifies the exact number of digits.
fractionDigits – Specifies maximum number of decimal places allowed.
whiteSpace – Specifies how to handle white spaces. The white spaces can be spaces, tags,
line feed, or carriage return.
Complex Types:
1) Elements:
Complex elements are the elements that contain some other elements or attributes.
The complex types of elements are:
i) Empty Elements
ii) Elements that contain text
iii) Elements that contain other elements
iv) Elements that contain other text as well other elements
i) Empty Elements:
Let us define the empty elements by the complexType.
Example [Student.xsd]:
<?xml version= “1.0” ?>
<xs:schema xmlns:xs=“ http://www.w3.org/2001/XMLschema”>
<xs:element name= “Student”>
<xs:complexType>
<xs:attribute name= “HTNo” type= “xs:integer”>
</xs:complexType>
C - 34
Web Technologies Unit-I
</xs:element>
</xs:schema>
XML Document[Student.xml]:
<?xml version="1.0" encoding="iso-8859-1" ?>
<Student xmlns:xsi = "http://www.w3.org/2001/XMLschema-instance"
xsi:nonamespaceschemalocation = "Student.xsd" HTNo="1343">
</Student>
ii) Elements that contain text only:
We have the elements that contain simple contents such as text and attributes.
Hence we must add the type as simpleContent in the schema definition. This
simpleContent element must have either extension or restriction.
Example [Student.xsd]:
<?xml version= “1.0” ?>
<xs:schema xmlns:xs=“ http://www.w3.org/2001/XMLschema”>
<xs:element name= “Student”>
<xs:complexType>
<xs:simpleContent>
<xs:extension base= “xs:integer”>
<xs:attribute name= “HTNo” type= “xs:integer”>
</xs:extension>
</xs:simpleContent>
</xs:complexType>
</xs:element>
</xs:schema>
XML Document[Student.xml]:
<?xml version="1.0" encoding="iso-8859-1" ?>
<Student xmlns:xsi = "http://www.w3.org/2001/XMLschema-instance"
xsi:nonamespaceschemalocation = "Student.xsd" HTNo="1343">
100
</Student>
iii) Elements that contain other elements
only: Example [Student.xsd]:
<?xml version= “1.0” ?>
<xs:schema xmlns:xs=“ http://www.w3.org/2001/XMLschema”>
<xs:element name= “Student”>
<xs:complexType>
<xs:sequence>
<xs:element name= “firstName” type= “xs:string”>
<xs:element name= “lastName” type= “xs:string”>
</xs:sequence>
</xs:complexType>
</xs:element>
C - 35
Web Technologies Unit-I
</xs:schema>
XML Document[Student.xml]:
<?xml version="1.0" encoding="iso-8859-1" ?>
<Student xmlns:xsi = "http://www.w3.org/2001/XMLschema-instance"
xsi:nonamespaceschemalocation = "Student.xsd">
<firstName>Ravi</firstName>
<lastName>Chythanya</lastName>
</Student>
iv) Elements that contain text as well as other
elements: Example [Student.xsd]:
<?xml version= “1.0” ?>
<xs:schema xmlns:xs=“ http://www.w3.org/2001/XMLschema”>
<xs:element name= “Student”>
<xs:complexType mixed= “true”>
<xs:sequence>
<xs:element name= “Name” type= “xs:string”>
<xs:element name= “HTNo” type= “xs:integer”>
</xs:sequence>
</xs:complexType>
</xs:element>
</xs:schema>
XML Document[Student.xml]:
<?xml version="1.0" encoding="iso-8859-1" ?>
<Student xmlns:xsi = "http://www.w3.org/2001/XMLschema-instance"
xsi:nonamespaceschemalocation = "Student.xsd">
My Dear Student <Name>Ravi</Name>
With Hall Ticket Number <HTNo>0536</HTNo>
</Student>
2) Indicators:
Indicators allow us to define the elements in the manner we want. Following are some
indicators that are available in XML Schema.
i) all
ii) choice
iii) sequence
iv) maxOccurs
v) minOccurs
C - 36
Web Unit-
UNIT-II
JAVASCRIPT AND JQUERY
INTRODUCTION:
JavaScript is the most popular scripting language on the internet, and works in all major
browsers, such as Internet Explorer, Fire fox, Chrome, Opera, and Safari.
What is JavaScript?
JavaScript was designed to add interactivity to HTML pages
JavaScript is a scripting language
A scripting language is a lightweight programming language
JavaScript is usually embedded directly into HTML pages
JavaScript is an interpreted language (means that scripts execute without preliminary
compilation)
Everyone can use JavaScript without purchasing a license
CS -
Web Unit-
Arithmetic operators are used to perform arithmetic between variables and/or values.
Given that y=5, the table below explains the arithmetic operators:
Assignment operators are used to assign values to JavaScript variables. Given that
x=10 and y=5, the table below explains the assignment operators:
CS -
Web Unit-
3) COMPARISON OPERATORS:
4) LOGICAL OPERATORS:
Logical operators are used to determine the logic between variables or values. Given
that x=6 and y=3.
5) CONDITIONAL OPERATORS:
JavaScript also contains a conditional operator that assigns a value to a variable based
on some condition.
Syntax:
variablename=(condition)?value1:value2
Example:
greeting=(visitor=="PRES")?"Dear President ":"Dear ";
If the variable visitor has the value of "PRES", then the variable greeting will be assigned
the value "Dear President" else it will be assigned "Dear".
CS -
Web Unit-
CONDITIONAL STATEMENTS
Very often when you write code, you want to perform different actions for different
decisions. You can use conditional statements in your code to do this.
In JavaScript we have the following conditional statements:
i) if statement - use this statement to execute some code only if a specified condition is true
ii) if...else statement - use this statement to execute some code if the condition is true and
another code if the condition is false
iii) if...else if....else statement - use this statement to select one of many blocks of code to be
executed
iv) switch statement - use this statement to select one of many blocks of code to be executed
i) IF STATEMENT
Syntax:
if (condition)
{
code to be executed if condition is true
}
Example:
<script type="text/javascript">
//Write a "Good morning" greeting if
//the time is less than 10
var d=new Date();
var time=d.getHours();
if (time<10)
{
document.write("<b>Good morning</b>");
}
</script>
Use the If...else statement to execute some code if a condition is true and another
code if the condition is not true.
Syntax:
if (condition)
{
code to be executed if condition is true
}
else
{
code to be executed if condition is not true
}
CS -
Web Unit-
Example:
<script type="text/javascript">
//If the time is less than 10, you will get a "Good morning" greeting.
//Otherwise you will get a "Good day" greeting.
var d = new Date();
var time = d.getHours();
if (time < 10)
{
document.write("Good morning!");
}
else
{
document.write("Good day!");
}
</script>
iii) IF...ELSE IF...ELSE STATEMENT:
Syntax:
if (condition1)
{
code to be executed if condition1 is true
}
else if (condition2)
{
code to be executed if condition2 is true
}
else
{
code to be executed if condition1 and condition2 are not true
}
Example:
<script type="text/javascript">
var d = new Date()
var time = d.getHours()
if (time<10)
document.write("<b>Good morning</b>");
else if (time>10 && time<16)
document.write("<b>Good day</b>");
else
document.write("<b>Hello World!</b>");
</script>
CS -
Web Unit-
Syntax:
switch(n)
{
case 1: execute code block 1; break;
case 2: execute code block 2; break;
default:
code to be executed if n is different from case 1 and 2
}
Example:
<script type="text/javascript">
//You will receive a different greeting based
//on what day it is. Note that Sunday=0,
//Monday=1, Tuesday=2, etc.
var d=new Date();
theDay=d.getDay();
switch (theDay)
{
case 5: document.write("Finally
Friday"); break;
case 6: document.write("Super Saturday");
break;
case 0: document.write("Sleepy
Sunday"); break;
default: document.write("I'm looking forward to this weekend!");
}
</script>
CS -
Web Unit-
i) ALERT BOX:
An alert box is often used if you want to make sure information comes through to
the user. When an alert box pops up, the user will have to click "OK" to proceed.
Syntax:
alert("sometext");
Example:
<html>
<head>
<script type="text/javascript">
function show_alert()
{
alert("You are Clicked Me ");
}
</script>
</head>
<body>
<input type="button" onClick="show_alert()" value="Click Me " />
</body>
</html>
A confirm box is often used if you want the user to verify or accept something.
The user will have to click either "OK" or "Cancel" to proceed. If the user clicks "OK",
the box returns true. If the user clicks "Cancel", the box returns false.
Syntax:
confirm("sometext");
Example:
<html>
<head>
<script type="text/javascript">
function show_confirm()
{
var r=confirm("Press a button");
if (r==true)
CS -
Web Unit-
{
alert("You pressed OK!");
}
else
{
alert("You pressed Cancel!");
}
}
</script>
</head>
<body>
<input type="submit" onClick="show_confirm()" value="Clicked Me " />
</body>
</html>
A prompt box is often used if you want the user to input a value before entering a
page. When a prompt box pops up, the user will have to click either "OK" or "Cancel" to
proceed after entering an input value. If the user clicks "OK" the box returns the input
value. If the user clicks "Cancel" the box returns null.
Syntax:
prompt("sometext","defaultvalue");
Example:
<html>
<head>
<script type="text/javascript">
function show_prompt()
{
var name=prompt("Please enter your name","Harry Potter");
if (name!=null && name!="")
{
document.write("Hello " + name + "! How are you today?");
}
}
</script>
</head>
<body>
<input type="button" onclick="show_prompt()" value="Show prompt box" />
</body>
</html>
CS -
Web Unit-
JAVASCRIPT FUNCTIONS
To keep the browser from executing a script when the page loads, you can put your script
into a function. A function contains code that will be executed by an event or by a call to the
function. You may call a function from anywhere within a page (or even from other pages if the
function is embedded in an external .js file). Functions can be defined both in the <head> and in
the <body> section of a document. However, to assure that a function is read/loaded by the
browser before it is called, it could be wise to put functions in the <head> section.
Syntax:
function function-name(var1,var2,...,varX)
{
some code;
}
The parameters var1, var2, etc. are variables or values passed into the function. The { and
the } defines the start and end of the function.
Note: A function with no parameters must include the parentheses () after the function name.
Note: Do not forget about the importance of capitals in JavaScript! The word function must be
written in lowercase letters, otherwise a JavaScript error occurs! Also note that you must call a
function with the exact same capitals as in the function name.
Example:
<html>
<head>
<script type="text/javascript">
function displaymessage()
{
alert("Hello World!");
}
</script>
</head>
<body>
<form>
<input type="button" value="Click me" onClick="displaymessage()" />
</form>
</body>
</html>
If the line: alert("Hello world!!") in the example above had not been put within a
function, it would have been executed as soon as the page was loaded. Now, the script is not
executed before a user hits the input button. The function displaymessage() will be executed if
the input button is clicked.
CS -
Web Unit-
The return statement is used to specify the value that is returned from the function. So,
functions that are going to return a value must use the return statement. The example below
returns the product of two numbers (a and b):
Example:
<html>
<head>
<script type="text/javascript">
function product(a,b)
{
return a*b;
}
</script>
</head>
<body>
<script type="text/javascript">
document.write(product(4,3));
</script>
</body>
</html>
If you declare a variable within a function, the variable can only be accessed within that
function. When you exit the function, the variable is destroyed. These variables are called local
variables. You can have local variables with the same name in different functions, because each
is recognized only by the function in which it is declared. If you declare a variable outside a
function, all the functions on your page can access it. The lifetime of these variables starts when
they are declared, and ends when the page is closed.
JAVASCRIPT LOOPS
Often when you write code, you want the same block of code to run over and over again
in a row. Instead of adding several almost equal lines in a script we can use loops to perform a
task like this. In JavaScript, there are two different kinds of loops:
i) for - loops through a block of code a specified number of times
ii) while - loops through a block of code while a specified condition is true
i) FOR LOOP
Syntax:
for (var=startvalue;var<=endvalue;var=var+increment)
{
code to be executed
}
CS -
Web Unit-
Example:
The example below defines a loop that starts with i=0. The loop will continue to
run as long as i is less than, or equal to 5. i will increase by 1 each time the loop runs.
Note: The increment parameter could also be negative, and the <= could be any
comparing statement.
<html>
<body>
<script type="text/javascript">
var i=0;
for (i=0;i<=5;i++)
{
document.write("The number is " + i);
document.write("<br />");
}
</script>
</body>
</html>
The while loop loops through a block of code while a specified condition is true.
Syntax:
while (var<=endvalue)
{
code to be executed
}
<html>
<body>
<script type="text/javascript">
var i=0;
while (i<=5)
{
document.write("The number is " + i);
document.write("<br />");
i++;
}
</script> </body></html>
CS -
Web Unit-
The do...while loop is a variant of the while loop. This loop will execute the block
of code ONCE, and then it will repeat the loop as long as the specified condition is true.
Syntax:
do
{
code to be executed
} while (var<=endvalue);
Example:
The example below uses a do...while loop. The do...while loop will always be
executed at least once, even if the condition is false, because the statements are executed
before the condition is tested:
<html>
<body>
<script type="text/javascript">
var i=0;
do
{
document.write("The number is " + i);
document.write("<br />");
i++;
}
while (i<=5);
</script>
</body>
</html>
CS -
Web Unit-
CS -
Web Unit-
for (x in mycars)
{
document.write(mycars[x] + "<br />");
}
</script>
</body>
</html>
JAVASCRIPT EVENTS:
By using JavaScript, we have the ability to create dynamic web pages. Events are actions
that can be detected by JavaScript. Every element on a web page has certain events which can
trigger a JavaScript. For example, we can use the onClick event of a button element to indicate
that a function will run when a user clicks on the button. We define the events in the HTML tags.
Examples of events:
A mouse click
A web page or an image loading
Mousing over a hot spot on the web page
Selecting an input field in an HTML form
Submitting an HTML form
A keystroke
Note: Events are normally used in combination with functions, and the function will not be
executed before the event occurs!
ONSUBMIT:
The onSubmit event is used to validate ALL form fields before submitting it. Below is an
example of how to use the onSubmit event. The checkForm() function will be called when the
user clicks the submit button in the form. If the field values are not accepted, the submit should
CS -
Web Unit-
be cancelled. The function checkForm() returns either true or false. If it returns true the form will
be submitted, otherwise the submit will be cancelled:
<form method="post" action="xxx.htm" onsubmit="return checkForm()">
CS -
Web Unit-
catch(err)
{
txt="There was an error on this page.\n\n";
txt+="Error description: " + err.description + "\n\n";
txt+="Click OK to continue.\n\n";
alert(txt);
}
}
</script>
</head>
<body>
<input type="button" value="View message" onclick="message()" />
</body>
</html>
The next example uses a confirm box to display a custom message telling users they can
click OK to continue viewing the page or click Cancel to go to the homepage. If the confirm
method returns false, the user clicked Cancel, and the code redirects the user. If the confirm
method returns true, the code does nothing:
Example:
<html>
<head>
<script type="text/javascript">
var txt="";
function message()
{
try {
adddlert("Welcome guest!");
}
catch(err) {
txt="There was an error on this page.\n\n";
txt+="Click OK to continue viewing this page,\n";
txt+="or Cancel to return to the home page.\n\n";
if(!confirm(txt))
{
document.location.href="http://www.w3schools.com/";
}
}
}
</script>
</head>
<body>
<input type="button" value="View message" onclick="message()" />
</body>
</html>
CS -
Web Unit-
CS -
Web Unit-
}
}
</script>
</body>
</html>
CS -
Web Unit-
Properties:
Properties are the values associated with an object. In the following example we are using
the length property of the String object to return the number of characters in a string:
<script type="text/javascript">
var txt="Hello World!";
document.write(txt.length);
</script>
The output of the code above will be: 12
Methods:
Methods are the actions that can be performed on objects. In the following example we
are using the toUpperCase() method of the String object to display a text in uppercase letters:
<script type="text/javascript">
var str="Hello world!";
document.write(str.toUpperCase());
</script>
STRING OBJECT:
The String object is used to manipulate a stored piece of text.
Examples of use:
The following example uses the length property of the String object to find the length of a string:
var txt="Hello world!";
document.write(txt.length);
CS -
Web Unit-
2. Style Strings
<html>
<body>
<script type="text/javascript">
var txt = "Hello World!";
document.write("<p>Big: " + txt.big() + "</p>");
document.write("<p>Small: " + txt.small() + "</p>");
document.write("<p>Bold: " + txt.bold() + "</p>");
document.write("<p>Italic: " + txt.italics() + "</p>");
document.write("<p>Fixed: " + txt.fixed() + "</p>");
document.write("<p>Strike: " + txt.strike() + "</p>");
document.write("<p>Fontcolor: " + txt.fontcolor("green") + "</p>");
document.write("<p>Fontsize: " + txt.fontsize(6) + "</p>");
document.write("<p>Subscript: " + txt.sub() + "</p>");
document.write("<p>Superscript: " + txt.sup() + "</p>");
document.write("<p>Link: " + txt.link("http://www.w3schools.com") + "</p>");
document.write("<p>Blink: " + txt.blink() + " (does not work in IE, Chrome, or
Safari)</p>");
</script>
</body>
</html>
Output:
CS -
Web Unit-
Fontsize:Hello World!
Subscript: Hello World!
Superscript: Hello World!
Link: Hello World!
Blink: Hello World! (does not work in IE, Chrome, or Safari)
CS -
Web Unit-
</script>
</body>
</html>
Output: Visit W3Schools!
Set Dates
We can easily manipulate the date by using the methods available for the Date object. In
the example below we set a Date object to a specific date (14th January 2010):
CS -
Web Unit-
if (myDate>today)
{
alert("Today is before 14th January 2010");
}
else
{
alert("Today is after 14th January 2010");
}
DATE OBJECT EXAMPLES:
1. Use Date() to Return Today's Date And Time
<html>
<body>
<script type="text/javascript">
var d=new Date();
document.write(d);
</script>
</body>
</html>
Output: Wed Jan 12 2011 14:38:08 GMT+0530 (India Standard Time)
2. Use getTime() to Calculate the Years Since 1970
<html>
<body>
<script type="text/javascript">
var d=new Date();
document.write(d.getTime() + " milliseconds since 1970/01/01");
</script>
CS -
Web Unit-
</body>
</html>
Output: 1294823298285 milliseconds since 1970/01/01
5. Use getDay() and An Array to Write a Weekday, and Not Just A Number
<html>
<body>
<script type="text/javascript">
var d=new Date();
var weekday=new Array(7);
weekday[0]="Sunday";
weekday[1]="Monday";
weekday[2]="Tuesday";
weekday[3]="Wednesday";
weekday[4]="Thursday";
weekday[5]="Friday";
CS -
Web Unit-
weekday[6]="Saturday";
document.write("Today is " + weekday[d.getDay()]);
</script>
</body>
</html>
Output: Today is Wednesday
6. Display a Clock
<html>
<head>
<script type="text/javascript">
function startTime()
{
var today=new Date();
var h=today.getHours();
var m=today.getMinutes();
var s=today.getSeconds();
// add a zero in front of numbers<10
m=checkTime(m);
s=checkTime(s);
document.getElementById('txt').innerHTML=h+":"+m+":"+s;
t=setTimeout('startTime()',500);
}
function checkTime(i)
{
if (i<10)
{
i="0" + i;
}
return i;
}
</script>
</head>
<body onload="startTime()">
<div id="txt"></div>
</body>
</html>
Output: 14:42:13
CS -
Web Unit-
An array can be defined in three ways. The following code creates an Array object called
myCars:
1st Method:
You can refer to a particular element in an array by referring to the name of the array and the
index number. The index number starts at 0. The following code line:
document.write(myCars[0]);
Saab
CS -
Web Unit-
To modify a value in an existing array, just add a new value to the array with a specified index
number:
myCars[0]="Opel";
Now, the following code line:
document.write(myCars[0]);
will result in the following output: Opel
<html>
<body>
<script type="text/javascript">
var parents = ["Jani", "Tove"];
var children = ["Cecilie", "Lone"];
var family =
parents.concat(children);
document.write(family);
</script>
</body>
</html>
CS -
Web Unit-
CS -
Web Unit-
CS -
Web Unit-
CS -
Web Unit-
Mathematical Constants:
JavaScript provides eight mathematical constants that can be accessed from the Math
object. These are: E, PI, square root of 2, square root of 1/2, natural log of 2, natural log of 10,
base-2 log of E, and base-10 log of E. You may reference these constants from your JavaScript
like this:
Math.E
Math.PI
Math.SQRT2
Math.SQRT1_2
Math.LN2
Math.LN10
Math.LOG2E
Math.LOG10E
Mathematical Methods:
In addition to the mathematical constants that can be accessed from the Math object there
are also several methods available. The following example uses the round() method of the Math
object to round a number to the nearest integer:
document.write(Math.round(4.7));
Output: 5
The following example uses the random() method of the Math object to return a random
number between 0 and 1:
document.write(Math.random());
Output: 0.9306157949324372
The following example uses the floor() and random() methods of the Math object to
return a random number between 0 and 10:
document.write(Math.floor(Math.random()*11));
Output: 6
CS -
Web Unit-
</html>
2. Use random() to Return a Random Number Between 0 and 1:
<html>
<body>
<script type="text/javascript">
//return a random number between 0 and 1
document.write(Math.random() + "<br />");
//return a random integer between 0 and 10
document.write(Math.floor(Math.random()*11));
</script>
</body>
</html>
3. Use max() to return the Number With the Highest Value of Two Specified Numbers:
<html>
<body>
<script type="text/javascript">
document.write(Math.max(5,10) + "<br />");
document.write(Math.max(0,150,30,20,38) + "<br
/>"); document.write(Math.max(-5,10) + "<br />");
document.write(Math.max(-5,-10) + "<br />");
document.write(Math.max(1.5,2.5));
</script>
</body>
</html>
4. Use min() to Return the Number With the Lowest Value of Two Specified Numbers:
<html>
<body>
<script type="text/javascript">
document.write(Math.min(5,10) + "<br />");
document.write(Math.min(0,150,30,20,38) + "<br />");
document.write(Math.min(-5,10) + "<br />");
document.write(Math.min(-5,-10) + "<br />");
document.write(Math.min(1.5,2.5));
</script>
</body>
</html>
CS -
Web Unit-
{
if (degree=="C")
{
F=document.getElementById("c").value * 9 / 5 + 32;
document.getElementById("f").value=Math.round(F);
}
else
{
C=(document.getElementById("f").value -32) * 5 / 9;
document.getElementById("c").value=Math.round(C);
}
}
</script>
</head>
<body>
<p></p><b>Insert a number into one of the input fields
below:</b></p>
<form>
<input id="c" name="c" onkeyup="convert('C')"> degrees
Celsius<br />
equals<br />
<input id="f" name="f" onkeyup="convert('F')"> degrees
Fahrenheit
</form>
<p>Note that the <b>Math.round()</b> method is used, so that the
result will be returned as an integer.</p>
</body>
</html>
CS -
Web Unit-
Method Description
alert() Displays an alert box with a message and an OK button
blur() Removes focus from the current window
close() Closes the current window
confirm() Displays a dialog box with a message and an OK and a Cancel button
createPopup() Creates a pop-up window
focus() Sets focus to the current window
open() Opens a new browser window
print() Prints the content of the current window
CS -
Web Unit-
prompt() Displays a dialog box that prompts the visitor for input
resizeBy() Resizes the window by the specified pixels
resizeTo() Resizes the window to the specified width and height
CS -
Web Unit-
<script type="text/javascript">
function show_confirm()
{
var r=confirm("Press a button!");
if (r==true)
{
alert("You pressed OK!");
}
else
{
alert("You pressed Cancel!");
}
}
</script>
</head>
<body>
<input type="button" onclick="show_confirm()" value="Show a confirm
box" />
</body>
</html>
CS -
Web Unit-
window.open("http://www.w3schools.com","_blank","toolbar=yes,
location=yes, directories=no, status=no, menubar=yes, scrollbars=yes,
resizable=no, copyhistory=yes, width=400, height=400");
}
</script>
</head>
<body>
<form>
<input type="button" value="Open Window" onclick="open_win()">
</form>
</body>
</html>
CS -
Web Unit-
9. A simple timing:
<html>
<head>
<script type="text/javascript">
function timeText()
{
var t1=setTimeout("document.getElementById('txt').value='2
seconds!'",2000);
var t2=setTimeout("document.getElementById('txt').value='4
seconds!'",4000);
var t3=setTimeout("document.getElementById('txt').value='6
seconds!'",6000);
}
</script>
</head>
<body>
<form>
<input type="button" value="Display timed text!" onclick="timeText()"/>
<input type="text" id="txt" />
</form>
<p>Click the button above. The input field will tell you when two, four,
and six seconds have passed…..</p>
</body>
</html>
CS -
Web Unit-
JQUERY INTRODUCTION:
jQuery is a fast and concise JavaScript Library created by John Resig in 2006 with a nice motto:
Write less, do more. jQuery simplifies HTML document traversing, event handling, animating,
and Ajax interactions for rapid web development. jQuery is a JavaScript toolkit designed to
simplify various tasks by writing less code. Here is the list of important core features supported
by jQuery:
DOM manipulation: The jQuery made it easy to select DOM elements, negotiate them
and modifying their content by using cross-browser open source selector engine called
Sizzle.
Event handling: The jQuery offers an elegant way to capture a wide variety of events,
such as a user clicking on a link, without the need to clutter the HTML code itself with
event handlers.
AJAX Support: The jQuery helps you a lot to develop a responsive and feature-rich site
using AJAX technology.
Animations: The jQuery comes with plenty of built-in animation effects which you can
use in your websites.
Lightweight: The jQuery is very lightweight library - about 19KB in size (Minified and
gzipped).
Cross Browser Support: The jQuery has cross-browser support, and works well in IE
6.0+, FF 2.0+, Safari 3.0+, Chrome and Opera 9.0+
Latest Technology: The jQuery supports CSS3 selectors and basic XPath syntax.
Installation of jQuery:
There are two ways to use jQuery.
Local Installation − You can download jQuery library on your local machine and
include it in your HTML code.
CDN Based Version − You can include jQuery library into your HTML code directly
from Content Delivery Network (CDN).
Local Installation:
Go to the https://jquery.com/download/ to download the latest version available.
Now, insert downloaded jquery-2.1.3.min.js file in a directory of your website, e.g.
C:/your-website-directory/jquery/jquery-2.1.3.min.js.
Example:
Now, you can include jQuery library in your HTML file as follows:
<html>
<head>
<title>The jQuery Example</title>
<script
type="text/javascript"src="/jquery/jquery-
2.1.3.min.js"></script>
<script type="text/javascript">
$(document).ready(function()
{
CS -
Web Unit-
document.write("Hello, World!");
});
</script>
</head>
<body>
<h1>Hello</h1>
</body>
</html>
This will produce the following result –
Hello, World!
Example:
Now, you can include jQuery library in your HTML file as follows:
<html>
<head>
<title>The jQuery Example</title>
<script type="text/javascript" src=
"http://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
</script>
<script type="text/javascript">
$(document).ready(function({
document.write("Hello,
World!");
});
</script>
</head>
<body>
<h1>Hello</h1>
</body>
</html>
This will produce the following result –
Hello, World!
$(document).ready(function() {
//write the stuff when DOM is ready
});
To call upon any jQuery library function, use HTML script tags as shown below:
CS -
Web Unit-
CS -
Web Unit-
<html>
<head>
<title>The jQuery Example</title>
<script type="text/javascript"
src="/jquery/jquery 1.3.2.min.js"></script>
<script type="text/javascript" language="javascript">
$(document).ready(function({
$
("div").click(functio
n() { Alert("Hello
world!");
});
});
</script>
</head>
<body>
<div id="newdiv">
Click on this to see a dialogue box.
</div>
</body>
</html>
Creating and Executing Custom Scripts:
It is better to write our custom code in custom JavaScript file: custom.js, as follows:
/* Filename: custom.js */
$(document).ready(function() {
$
("div").click(function
() { alert("Hello
world!");
});
});
Now we can include custom.js file in our HTML file as follows:
<html>
<head>
<title>The jQuery Example</title>
<script type="text/javascript"
src="/jquery/jquery- 1.3.2.min.js"></script>
<script type="text/javascript" src="/jquery/custom.js"></script>
</head>
<body>
<div id="newdiv">
Click on this to see a dialogue box.
</div>
</body>
</html>
This will produce the following result:
Click on this to see a dialogue box.
CS -
Web Unit-
CS -
Web Unit-
jQuery Selectors:
The jQuery library binds the power of Cascading Style Sheets (CSS) selectors to let us
quickly and easily access elements or groups of elements in the Document Object Model
(DOM).
A jQuery Selector is a function which makes use of expressions to find out matching
elements from a DOM based on the given criteria.
All the above items can be used either on their own or in combination with other selectors. All
the jQuery selectors are based on the same principle except some tweaking.
NOTE: The factory function $() is a synonym of jQuery() function. So in case you are using any
other JavaScript library where $ sign is conflicting with something else then you can replace $
sign by jQuery name and you can use function jQuery() instead of $().
Example:
Following is a simple example which makes use of Tag Selector. This would select all the
elements with a tag name p.
<html>
<head>
<title>the title</title>
<script type="text/javascript"
src="/jquery/jquery- 1.3.2.min.js"></script>
<script type="text/javascript" language="javascript">
$
(document).ready(function
() { var pars = $("p");
for( i=0; i<pars.length; i++ ){
alert("Found paragraph: " + pars[i].innerHTML);
}
});
</script>
</head>
<body>
CS -
Web Unit-
CS -
Web Unit-
<div>
<p class="myclass">This is a paragraph.</p>
<p id="myid">This is second paragraph.</p>
<p>This is third paragraph.</p>
</div>
</body>
</html>
This will produce the the following result:
Using of Selectors:
The selectors are very useful and would be required at every step while using jQuery. They get
the exact element that you want from your HTML document.
Following table lists down few basic selectors and explains them with examples.
Selector Description
Name Selects all elements which match with the given element Name.
#ID Selects a single element which matches with the given ID.
.Class Selects all elements which matches with the given Class.
Universal (*) Selects all elements available in a DOM.
Multiple Elements Selects the combined results of all the specified selectors E, F or G.
E, F,G
Parameters:
Here is the description of all the parameters used by this selector –
tagname − Any standard HTML tag name like div, p, em, img, li etc.
Returns:
Like any other jQuery selector, this selector also returns an array filled with the found elements.
Example:
$('p') − Selects all elements with a tag name of p in the document.
$('div') − Selects all elements with a tag name of div in the document.
Following example would select all the divisions and will apply yellow color to their background
CS -
Web Unit-
<html>
<head>
<title>The Selecter Example</title>
<script type="text/javascript"
src="http://ajax.googleapis.com/ajax/libs/jquery/2.1.3
/jquer y.min.js">
</script>
<script type="text/javascript" language="javascript">
$(document).ready(function() {
/* This would select all the divisions */
$("div").css("background-color", "yellow");
});
</script>
</head>
<body>
<div class="big" id="div1">
<p>This is first division of the DOM.</p> </div>
<div class="medium" id="div2">
<p>This is second division of the DOM.</p> </div>
<div class="small" id="div3">
<p>This is third division of the DOM</p>
</div>
</body>
</html>
This will produce the following result:
This is first division of the DOM.
Syntax:
Here is the simple syntax to use this selector −
Parameters:
Here is the description of all the parameters used by this selector –
Elementid: This would be an element ID. If the id contains any special characters
like periods or colons you have to escape those characters with backslashes.
Returns:
Like any other jQuery selector, this selector also returns an array filled with the found element.
CS -
Web Unit-
Example:
$('#myid') − Selects a single element with the given id myid.
$('div#yourid') − Selects a single division with the given id yourid.
Following example would select second division and will apply yellow color to its background
as below:
<html>
<head>
<title>The Selecter Example</title>
<script type="text/javascript"
src="http://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.m
in.js"
>
</script>
<script type="text/javascript" language="javascript">
$(document).ready(function() {
/* This would select second division only*/
$("#div2").css("background-color", "yellow");
});
</script>
</head>
<body>
<div class="big" id="div1">
<p>This is first division of the DOM.</p>
</div>
<div class="medium" id="div2">
<p>This is second division of the DOM.</p>
</div>
<div class="small" id="div3">
<p>This is third division of the DOM.</p>
</div>
</body>
</html>
This will produce the following result:
This is first division of the DOM.
This is second division of the DOM.
This is third division of the DOM.
Description:
The element class selector selects all the elements which match with the given class of the
elements.
Syntax:
Here is the simple syntax to use this selector:
$('.classid')
CS -
Web Unit-
CS -
Web Unit-
Parameters:
Here is the description of all the parameters used by this selector –
classid − This is class ID available in the document.
Returns:
Like any other jQuery selector, this selector also returns an array filled with the found elements.
Example:
$('.big') − Selects all the elements with the given class ID big.
$('p.small') − Selects all the paragraphs with the given class ID small.
$('.big.small') − Selects all the elements with a class of big and small.
Following example would select all divisions with class .big and will apply yellow color to its
background.
<html>
<head>
<title>The Selecter Example</title>
<script type="text/javascript"
src="http://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.m
in.js"
>
</script>
<script type="text/javascript" language="javascript">
$(document).ready(function() {
/* This would select second division only*/
$(".big").css("background-color", "yellow");
});
</script>
</head>
<body>
<div class="big" id="div1">
<p>This is first division of the DOM.</p> </div>
<div class="medium" id="div2">
<p>This is second division of the DOM.</p> </div>
<div class="small" id="div3">
<p>This is third division of the DOM</p> </div>
</body>
</html>
This will produce the following result:
Description:
The universal selector selects all the elements available in the document.
CS -
Web Unit-
CS -
Web Unit-
Syntax:
Here is the simple syntax to use this selector −
$('*')
Parameters:
Here is the description of all the parameters used by this selector
* − A symbolic star.
Returns:
Like any other jQuery selector, this selector also returns an array filled with the found elements.
Example:
$('*') selects all the elements available in the document.
Following example would select all the elements and will apply yellow color to their
background. Try to understand that this selector will select every element including head, body
etc.
<html>
<head>
<title>The Selecter Example</title>
<script type="text/javascript"
src="http://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.m
in.js"
>
</script>
<script type="text/javascript" language="javascript">
$(document).ready(function() {
/* This would select all the elements */
$("*").css("background-color", "yellow");
});
</script>
</head>
<body>
<div class="big" id="div1">
<p>This is first division of the DOM.</p> </div>
<div class="medium" id="div2">
<p>This is second division of the DOM.</p>
</div>
<div class="small" id="div3">
<p>This is third division of the DOM</p> </div>
</body>
</html>
This will produce the following result:
This is first division of the DOM.
CS -
Web Unit-
Syntax:
Here is the simple syntax to use this selector −
$('E, F, G,. ')
Parameters:
Here is the description of all the parameters used by this selector –
E − Any valid selector
F − Any valid selector
G − Any valid selector
Returns:
Like any other jQuery selector, this selector also returns an array filled with the found elements.
Example:
$('div, p') − selects all the elements matched by div or p.
$('p strong, .myclass') − selects all elements matched by strong that are descendants of an
element matched by p as well as all elements that have a class of myclass.
$('p strong, #myid') − selects a single element matched by strong that is descendant of an
element matched by p as well as element whose id is myid.
Following example would select elements with class ID big and element with ID div3 and will apply yellow
color to its background –
<html>
<head>
<title>The Selecter Example</title>
<script type="text/javascript"
src="http://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.m
in.js"
>
</script>
<script type="text/javascript" language="javascript">
$(document).ready(function() {
$(".big, #div3").css("background-color", "yellow");
});
</script>
</head>
<body>
<div class="big" id="div1">
<p>This is first division of the DOM.</p> </div>
<div class="medium" id="div2">
<p>This is second division of
the DOM.</p> </div>
<div class="small" id="div3">
<p>This is third division of the DOM</p> </div>
CS -
Web Unit-
CS -
Web Unit-
</body>
</html>
This will produce the following result:
This is first division of the DOM.
This is second division of the DOM.
This is third division of the DOM
$("a[target='_blank']") Selects all <a> elements with a target attribute value equal to "_blank"
Selects all <a> elements with a target attribute value NOT equal to
$("a[target!='_blank']")
"_blank"
$(":button") Selects all <button> elements and <input> elements of type="button"
$("tr:even") Selects all even <tr> elements
$("tr:odd") Selects all odd <tr> elements
jQuery DOM:
JQuery provides methods to manipulate DOM in efficient way. You do not need to write big
code to modify the value of any element's attribute or to extract HTML code from a paragraph or
division.
JQuery provides methods such as .attr(), .html(), and .val() which act as getters, retrieving
information from DOM elements for later use.
Content Manipulation:
The html( ) method gets the html contents (innerHTML) of the first matched element.
Here is the syntax for the method −
selector.html( )
Example:
<html>
<head>
<title>The jQuery Example</title>
<script type = "text/javascript"
src =
"https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js">
</script>
CS -
Web Unit-
<style>
#division{ margin:10px;padding:12px; border:2px solid #666;
width:60px;}
</style>
</head>
<body>
<p>Click on the square below:</p>
<span id = "result"> </span>
text( val):
The text( val ) method sets the combined text contents of all matched elements.
Syntax:
selector.text( val )
Example:
<html>
<head>
<title>The jQuery Example</title>
<script type = "text/javascript"
src =
"https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
</script>
<style>
.div{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
</style>
</head>
<body>
<p>Click on any square below to see the result:</p>
CS -
Web Unit-
jQuery Events:
jQuery is tailor-made to respond to events in an HTML page. All the different visitors' actions
that a web page can respond to are called events. An event represents the precise moment when
something happens.
Examples:
moving a mouse over an element
selecting a radio button
clicking on an element
Here are some common DOM events:
Mouse Events Keyboard Events Form Events Document/Window Events
Click keypress submit load
dblclick keydown change resize
mouseenter keyup focus scroll
mouseleave blur unload
Syntax:
In jQuery, most DOM events have an equivalent jQuery method. To assign a click event to all
paragraphs on a page, you can do this:
$(selector).click();
Sometime you need to define what should happen when the event fires, then you must pass a
function to the event:
$(selector).click(function(){
// action goes here!!
});
click():
The click() method attaches an event handler function to an HTML element. The function is
executed when the user clicks on the HTML element.
CS -
Web Unit-
Example:
$("p").click(function(){
$(this).hide();
});
jQuery Attributes:
Some of the most basic components we can manipulate when it comes to DOM elements are the
properties and attributes assigned to those elements.
Most of these attributes are available through JavaScript as DOM node properties. Some of the
more common properties are −
className
tagName
id
href
title
rel
src
Consider the following HTML markup for an image element –
<img id = "imageid" src = "image.gif" alt = "Image" class = "myclass" title = "This is an
image"/>
In this element's markup, the tag name is img, and the markup for id, src, alt, class, and title
represents the element's attributes, each of which consists of a name and a value. jQuery gives us
the means to easily manipulate an element's attributes and gives us access to the element so that
we can also change its properties.
CS -
Web Unit-
CS -
Web Unit-
UNIT-III
AJAX AND ANGULAR JS
INTRODUCTION TO AJAX:
AJAX stands for Asynchronous JavaScript and XML. AJAX is a new technique for creating
better, faster, and more interactive web applications with the help of XML, HTML, CSS, and
Java Script.
Ajax uses XHTML for content, CSS for presentation, along with Document Object
Model and JavaScript for dynamic content display.
Conventional web applications transmit information to and from the sever using
synchronous requests. It means you fill out a form, hit submit, and get directed to a new
page with new information from the server.
With AJAX, when you hit submit, JavaScript will make a request to the server, interpret
the results, and update the current screen. In the purest sense, the user would never know
that anything was even transmitted to the server.
XML is commonly used as the format for receiving server data, although any format,
including plain text, can be used.
AJAX is a web browser technology independent of web server software.
A user can continue to use the application while the client program requests information
from the server in the background.
Intuitive and natural user interaction. Clicking is not required, mouse movement is a
sufficient event trigger.
Data-driven as opposed to page-driven.
AJAX cannot work independently. It is used in combination with other technologies to create
interactive webpages.
JavaScript:
Loosely typed scripting language.
JavaScript function is called when an event occurs in a page.
Glue for the whole AJAX operation.
DOM:
API for accessing and manipulating structured documents.
Represents the structure of XML and HTML documents.
CSS:
Allows for a clear separation of the presentation style from the content and may be
changed programmatically by JavaScript
XMLHttpRequest:
JavaScript object that performs asynchronous interaction with the server.
CS -96-
Web Unit-
NOTE − When we say that a browser does not support AJAX, it simply means that the browser
does not support the creation of Javascript object – XMLHttpRequest object.
Try {
// Opera 8.0+, Firefox, Safari
ajaxRequest = new XMLHttpRequest();
} catch (e) {
try {
ajaxRequest = new ActiveXObject(“Microsoft.XMLHTTP”);
} catch (e) {
CS -97-
Web Unit-
</body>
</html>
In the above JavaScript code, we try three times to make our XMLHttpRequest object. Our first
attempt –
ajaxRequest = new XMLHttpRequest();
It is for Opera 8.0+, Firefox, and Safari browsers. If it fails, we try two more times to make the
correct object for an Internet Explorer browser with –
ajaxRequest = new ActiveXObject(“Msxml2.XMLHTTP”);
ajaxRequest = new ActiveXObject(“Microsoft.XMLHTTP”);
If it doesn‟t work, then we can use a very outdated browser that doesn‟t support
XMLHttpRequest, which also means it doesn‟t support AJAX.
Most likely though, our variable ajaxRequest will now be set to whatever XMLHttpRequest
standard the browser uses and we can start sending data to the server.
CS -98-
Web Unit-
CS -99-
Web Unit-
function validateUserId() {
ajaxFunction();
// Here processRequest() is the callback function.
ajaxRequest.onreadystatechange = processRequest;
if (!target) target = document.getElementById("userid");
var url = "validate?id = " + escape(target.value);
ajaxRequest.open("GET", url, true);
ajaxRequest.send(null);
}
Assume you enter Zara in the userid box, then in the above request, the URL is set to "validate?
id = Zara".
CS -
Web Unit-
CS -
Web Unit-
The data returned from XMLHttpRequest calls will often be provided by back-end databases.
Besides XML, XMLHttpRequest can be used to fetch data in other formats, e.g. JSON or even
plain text.
You already have seen a couple of examples on how to create an XMLHttpRequest object.
Listed below are some of the methods and properties that you have to get familiar with.
XMLHttpRequest Methods
Method Name Description
abort( ) Cancels the current request.
getAllResponseHeaders() Returns the complete set of HTTP headers as a
string.
getResponseHeader( headerName ) Returns the value of the specified HTTP header.
open( method, URL )
open( method, URL, async )
Specifies the method, URL, and other optional
open( method, URL, async, userName )
attributes of a request.
open( method, URL, async, userName,
password )
The method parameter can have a value of "GET", "POST", or "HEAD". Other HTTP methods
such as "PUT" and "DELETE" (primarily used in REST applications) may be possible.
The "async" parameter specifies whether the request should be handled asynchronously or not.
"true" means that the script processing carries on after the send() method without waiting for a
response, and "false" means that the script waits for a response before continuing script
processing.
Method Name Description
send(content) Sends the request.
setRequestHeader( label, value ) Adds a label/value pair to the HTTP header to be sent.
XMLHttpRequest Properties:
Property Name Description
onreadystatechange An event handler for an event that fires at every state change.
readyState The readyState property defines the current state of the
XMLHttpRequest object.
responseText Returns the response as a string.
responseXML Returns the response as XML. This property returns an XML
document object, which can be examined and parsed using the W3C
DOM node tree methods and properties.
status Returns the status as a number (e.g., 404 for "Not Found" and 200 for
"OK").
statusText Returns the status as a string (e.g., "Not Found" or "OK").
CS -
Web Unit-
The following table provides a list of the possible values for the readyState property −
State Description
0 The request is not initialized.
1 The request has been set up.
2 The request has been sent.
3 The request is in process.
4 The request is completed.
readyState = 0: After you have created the XMLHttpRequest object, but before you
have called the open() method.
readyState = 1: After you have called the open() method, but before you have called
send().
readyState = 2: After you have called send().
readyState = 3: After the browser has established a communication with the server, but
before the server has completed the response.
readyState = 4: After the request has been completed, and the response data has been
completely received from the server.
CS -
Web Unit-
};
xhttp.open("GET", "cd_catalog.xml", true);
xhttp.send();
}
function myFunction(xml) {
var i;
var xmlDoc = xml.responseXML;
var table="<tr><th>Artist</th><th>Title</th></tr>";
var x = xmlDoc.getElementsByTagName("CD");
for (i = 0; i <x.length; i++) {
table += "<tr><td>" +
x[i].getElementsByTagName("ARTIST")[0].childNodes[0].nodeValue +
"</td><td>" + x[i].getElementsByTagName("TITLE")
[0].childNodes[0].nodeValue + "</td></tr>";
}
document.getElementById("demo").innerHTML = table;
}
</script>
</body>
</html>
cd_catalog.xml:
<CATALOG>
<CD>
<TITLE>EMPIRE BURLESQUE</TITLE>
<ARTIST>BOB DYLAN</ARTIST>
<COUNTRY>USA</COUNTRY>
<COMPANY>COLUMBIA</COMPANY>
<PRICE>10.90</PRICE>
<YEAR>1985</YEAR>
</CD>
<CD>
<TITLE>HIDE YOUR HEART</TITLE>
<ARTIST>BONNIE TYLER</ARTIST>
<COUNTRY>UK</COUNTRY>
<COMPANY>CBS RECORDS</COMPANY>
<PRICE>9.90</PRICE>
<YEAR>1988</YEAR>
</CD>
<CD>
<TITLE>GREATEST HITS</TITLE>
<ARTIST>DOLLY PARTON</ARTIST>
<COUNTRY>USA</COUNTRY>
<COMPANY>RCA</COMPANY>
<PRICE>9.90</PRICE>
<YEAR>1982</YEAR>
</CD>
<CD>
CS -
Web Unit-
Ajax.html:
<html>
<head>
<meta content = "text/html; charset = ISO-8859-1" http-equiv = "content-type">
<script type = "application/javascript">
function loadJSON(){
var data_file = "http://www.tutorialspoint.com/json/data.json";
var http_request = new XMLHttpRequest();
try{
// Opera 8.0+, Firefox, Chrome, Safari
http_request = new XMLHttpRequest();
}catch (e){
// Internet Explorer Browsers
try{
http_request = new ActiveXObject("Msxml2.XMLHTTP");
CS -
Web Unit-
}catch (e) {
try{
http_request = new ActiveXObject("Microsoft.XMLHTTP");
}catch (e){
// Something went wrong
alert("Your browser broke!");
return false;
}
}
}
http_request.onreadystatechange = function(){
if (http_request.readyState == 4 ){
// Javascript function JSON.parse to parse JSON data
var jsonObj = JSON.parse(http_request.responseText);
// jsonObj variable now contains the data structure and can
// be accessed as jsonObj.name and jsonObj.country.
document.getElementById("Name").innerHTML = jsonObj.name;
document.getElementById("Country").innerHTML = jsonObj.country;
}
}
http_request.open("GET", data_file, true);
http_request.send();
}
</script>
<title>tutorialspoint.com JSON</title>
</head>
<body>
<h1>Cricketer Details</h1>
<table class = "src">
<tr>
<th>Name</th>
<th>Country</th>
</tr>
<tr>
<td>
<div id = "Name">Sachin</div>
</td>
<td>
<div id = "Country">India</div>
</td>
</tr>
</table>
<div class = “central”>
<button type = “button” onclick = “loadJSON()”>Update Details </button>
</div>
</body>
CS -
Web Unit-
</html>
Given below is the input file data.json, having data in JSON format which will be uploaded
asynchronously when we click the Update Detail button.
data.json:
{“name”: “Brett”, “country”: “Australia”}
Angular
Angular JS is aJSstructural
is a powerful JavaScript
framework for based
dynamicdevelopment
web apps.framework
It lets youtouse
create
HTMLRICHas your
Internet
template Application
language (RIA).
and lets you extend HTML's syntax to express your application's
Angular
components JS provides
clearly developers
and succinctly. optionsdata
Angular's to write client
binding andside applicationinjection
dependency (using JavaScript)
eliminate
much ofin the
a clean
codeMVC (Model View
you currently have Controller) way.
to write. And it all happens within the browser, making it
Application
an ideal partner withwritten in Angular
any server JS is cross-browser compliant. Angular JS automatically
technology.
handles JavaScript code suitable for each browser.
Angular JS is open source, completely free, and used by thousands of developers around
the world. It is licensed under the Apache License version 2.0.
CS -
Web Unit-
Using numbers:
<p>Expense on Books : {{cost * quantity}} Rs</p>
Using strings:
<p>Hello {{student.firstname + " " + student.lastname}}!</p>
CS -
Web Unit-
Using object:
<p>Roll No: {{student.rollno}}</p>
Using array
<p>Marks(Math): {{marks[3]}}</p>
Example:
Following example will showcase all the above mentioned expressions.
testAngularJS.html
<html>
<head>
<title>AngularJS Expressions</title>
</head>
<body>
<h1>Sample Application</h1>
<div ng-app = "" ng-init = "quantity = 1;cost = 30; student =
{firstname:'Mahesh',lastname:'Parashar',rollno:101};marks =
[80,90,75,73,60]">
<p>Hello {{student.firstname + " " + student.lastname}}!</p>
<p>Expense on Books : {{cost * quantity}} Rs</p>
<p>Roll No: {{student.rollno}}</p>
<p>Marks(Math): {{marks[3]}}</p>
</div>
<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js
"></script>
</body>
</html>
ng-app directive:
ng-app directive starts an AngularJS Application. It defines the root element. It automatically
initializes or bootstraps the application when web page containing AngularJS Application is
loaded. It is also used to load various AngularJS modules in AngularJS Application. In following
example, we've defined a default AngularJS application using ng-app attribute of a div element.
<div ng-app = "">
...
</div>
CS -
Web Unit-
ng-init directive:
ng-init directive initializes an AngularJS Application data. It is used to put values to the variables
to be used in the application. In following example, we'll initialize an array of countries. We're
using JSON syntax to define array of countries.
<div ng-app = "" ng-init = "countries = [{locale:'en-US',name:'United
States'}, {locale:'en-GB',name:'United Kingdom'}, {locale:'en-
FR',name:'France'}]">
...
</div>
ng-model directive:
This directive binds the values of AngularJS application data to HTML input controls. In
following example, we've defined a model named "name".
<div ng-app = "">
...
<p>Enter your Name: <input type = "text" ng-model = "name"></p>
</div>
ng-repeat directive:
ng-repeat directive repeats html elements for each item in a collection. In following example,
we've iterated over array of countries.
<div ng-app = "">
...
<p>List of Countries with locale:</p>
<ol>
<li ng-repeat = "country in countries">
{{ 'Country: ' + country.name + ', Locale: ' + country.locale }}
</li>
</ol>
</div>
Example:
Following example will showcase all the above mentioned directives.
testAngularJS.html:
<html>
<head>
<title>AngularJS Directives</title>
</head>
<body>
<h1>Sample Application</h1>
<div ng-app = "" ng-init = "countries = [{locale:'en-US',name:'United
States'}, {locale:'en-GB',name:'United Kingdom'}, {locale:'en-
FR',name:'France'}]">
<p>Enter your Name: <input type = "text" ng-model = "name"></p>
<p>Hello <span ng-bind = "name"></span>!</p>
<p>List of Countries with local: </p>
<ol>
<li ng-repeat = "country in countries">
{{ 'Country: ' + country.name + ', Locale: ' + country.locale
}}
</li>
</ol>
CS -
Web Unit-
</div>
<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"
></script>
</body>
</html>
Angular JS Controllers:
AngularJS application mainly relies on controllers to control the flow of data in the application.
A controller is defined using ng-controller directive. A controller is a JavaScript object
containing attributes/properties and functions. Each controller accepts $scope as a parameter
which refers to the application/module that controller is to control.
<div ng-app = "" ng-controller = "studentController">
...
</div>
Here we've declared a controller studentController using ng-controller directive. As a next step
we'll define the studentController as follows −
<script>
function studentController($scope) {
$scope.student = {
firstName: "Mahesh",
lastName: "Parashar",
fullName: function() {
var studentObject;
studentObject = $scope.student;
return studentObject.firstName + " " + studentObject.lastName;
}
};
}
</script>
Now we can use studentController's student property using ng-model or using expressions as
follows.
Enter first name: <input type = "text" ng-model = "student.firstName"><br>
Enter last name: <input type = "text" ng-model = "student.lastName"><br>
<br>
You are entering: {{student.fullName()}}
CS -
Web Unit-
testAngularJS.html:
<html>
<head>
<title>Angular JS Controller</title>
<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></scr
ipt>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller('studentController', function($scope) {
$scope.student = {
firstName: "Mahesh",
lastName: "Parashar",
fullName: function() {
var studentObject;
studentObject = $scope.student;
return studentObject.firstName + " " +
studentObject.lastName;
}
};
});
</script>
</body>
</html>
Angular JS Forms:
AngularJS enriches form filling and validation. We can use ng-click to handle AngularJS click
on button and use $dirty and $invalid flags to do the validations in seemless way. Use novalidate
with a form declaration to disable any browser specific validation. Forms controls makes heavy
use of Angular events. Let's have a quick look on events first.
CS -
Web Unit-
Events:
AngularJS provides multiple events which can be associated with the HTML controls. For
example ng-click is normally associated with button. Following are supported events in Angular
JS.
ng-click
ng-dbl-click
ng-mousedown
ng-mouseup
ng-mouseenter
ng-mouseleave
ng-mousemove
ng-mouseover
ng-keydown
ng-keyup
ng-keypress
ng-change
ng-click:
Reset data of a form using on-click directive of a button.
<input name = "firstname" type = "text" ng-model = "firstName" required>
<input name = "lastname" type = "text" ng-model = "lastName" required>
<input name = "email" type = "email" ng-model = "email" required>
<button ng-click = "reset()">Reset</button>
<script>
function studentController($scope) {
$scope.reset = function(){
$scope.firstName = "Mahesh";
$scope.lastName = "Parashar";
$scope.email = "MaheshParashar@tutorialspoint.com";
}
$scope.reset();
}
</script>
Validate data:
Following can be used to track error.
$dirty − states that value has been changed.
$invalid − states that value entered is invalid.
$error − states the exact error.
Example:
Following example will showcase all the above mentioned directives.
testAngularJS.html:
<html>
<head>
<title>Angular JS Forms</title>
<script src =
"https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></scr
ipt>
<style>
table, th , td {
CS -
Web Unit-
<tr>
<td>
<button ng-click = "reset()">Reset</button>
</td>
<td>
CS -
Web Unit-
</table>
</form>
</div>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller('studentController', function($scope) {
$scope.reset = function(){
$scope.firstName = "Mahesh";
$scope.lastName = "Parashar";
$scope.email = "MaheshParashar@tutorialspoint.com";
}
$scope.reset();
});
</script>
</body>
</html>
CS -
Web Unit-
UNIT-IV
JDBC AND SERVLETS
Introduction to Servlets:
Servlets are server side components that provide a powerful mechanism for developing
server side programs. Servlets provide component-based, platform-independent methods for
building Web-based applications. Using Servlets web developers can create fast and efficient
server side application which can run on any Servlet enabled web server. Servlets can access the
entire family of Java APIs, including the JDBC API to access enterprise databases. Servlets can
also access a library of HTTP-specific calls; receive all the benefits of the mature java language
including portability, performance, reusability, and crash protection. Today Servlets are the
popular choice for building interactive web applications. Servlet containers are usually the
components of web and application servers, such as BEA Weblogic Application Server, IBM
Web Sphere, Sun Java System Web Server, Sun Java System Application Server and others.
Servlets are not designed for a specific protocol. It is different thing that they are most
commonly used with the HTTP protocols Servlets uses the classes in the java packages
javax.servlet and javax.servlet.http. Servlets provides a way of creating the sophisticated server
side extensions in a server as they follow the standard framework and use the highly portable
java language.
Methods of Servlets:
A Generic Servlet contains the following five methods:
init():
public void init(ServletConfig config) throws ServletException
The init () method is called only once by the servlet container throughout the life of a
Servlet. By this init () method the Servlet get to know that it has been placed into service.
The Servlet cannot be put into the service if
The init () method does not return within a fix time set by the web server.
It throws a ServletException
Parameters - The init () method takes a ServletConfig object that contains the
initialization parameters and Servlet's configuration and throws a ServletException if an
exception has occurred.
service():
public void service(ServletRequest req, ServletResponse res) throws
ServletException, IOException
Once the Servlet starts getting the requests, the service() method is called by the Servlet
container to respond. The Servlet services the client's request with the help of two
objects. These two objects are javax.servlet.ServletRequest and javax.servlet. Servlet
Response are passed by the Servlet container. The status code of the response always
CS -
Web Unit-
should be set for a Servlet that throws or sends an error. Parameters - The service ()
method takes the ServletRequest object that contains the client's request and the object
ServletResponse contains the Servlet's response. The service() method throws
ServletException and IOException exception.
getServletConfig():
public ServletConfig getServletConfig()
This method contains parameters for initialization and startup of the Servlet and returns
a ServletConfig object. This object is then passed to the init method. When this interface
is implemented then it stores the ServletConfig object in order to return it. It is done by
the generic class which implements this interface.
Returns - the ServletConfig object
getServletInfo():
public String getServletInfo ()
The information about the Servlet is returned by this method like version, author etc. This
method returns a string which should be in the form of plain text and not any kind of
markup.
Returns - a string that contains the information about the Servlet
destroy():
public void destroy()
This method is called when we need to close the Servlet. That is before removing a
Servlet instance from service, the Servlet container calls the destroy() method. Once the
Servlet container calls the destroy() method, no service methods will be then called . That
is after the exit of all the threads running in the Servlet, the destroy() method is called.
Hence, the Servlet gets a chance to clean up all the resources like memory, threads etc
which are being held.
CS -
Web Unit-
4. Destroying the Servlet: If the Servlet is no longer needed for servicing any request, the
Servlet container calls the destroy() method . Like the init() method this method is also
called only once throughout the life cycle of the Servlet. Calling the destroy() method
indicates to the Servlet container not to sent the any request for service and the Servlet
releases all the resources associated with it. Java Virtual Machine claims for the memory
associated with the resources for garbage collection.
CS -
Web Unit-
class. Multiple concurrent requests are handled by separate threads so we can say that the
Servlets are highly scalable.
4. Safety: As Servlets are written in java, Servlets inherit the strong type safety of java
language. Java's automatic garbage collection and a lack of pointers mean that Servlets
are generally safe from memory management problems. In Servlets we can easily handle
the errors due to Java's exception handling mechanism. If any exception occurs then it
will throw an exception.
5. Integration: Servlets are tightly integrated with the server. Servlet can use the server to
translate the file paths, perform logging, check authorization, and MIME type mapping
etc.
6. Extensibility: The Servlet API is designed in such a way that it can be easily extensible.
As it stands today, the Servlet API support Http Servlets, but in later date it can be
extended for another type of Servlets.
7. Inexpensive: There are number of free web servers available for personal use or for
commercial purpose. Web servers are relatively expensive. So by using the free available
web servers you can add Servlet support to it.
CS -
Web Unit-
{
System.out.println("from service");
PrintWriter out=res.getWriter();
out.println("LifeCycle\n");
out.println("III CSE Students");
}
public void destroy()
{
System.out.println("destroy");
}
}
Step 4: Then set the classpath of the servlet-api.jar file in the variable CLASSPATH
inside the environment variable as “C:\Program Files\Apache Tomcat Foundation\
Tomcat x.x\lib\servlet-api.jar”. Then compile your servlet by using javac
LifeCycle.java.
Step 5: The next step is to create your web application folder. The name of the folder can
be any valid and logical name that represents your application (e.g. bank_apps,
airline_tickets_booking, shopping_cart,etc). But the most important criterion is that this
folder should be created under webapps folder. The path would be similar or close to this
- C:\Program Files\Apache Software Foundation\Tomcat 6.0\webapps. For demo
purpose, let us create a folder called example programs under the webapps folder.
Step 6: Next create the WEB-INF folder in C:\Program Files\Apache Software
Foundation\Tomcat 6.0\webapps\Example Programs folder.
Step 7: Then create the web.xml file and the classes folder. Ensure that the web.xml and
classes folder are created under the WEB-INF folder. The web.xml file contains the
following information.
The servlet information
The mapping information from the server to our web application.
Step 8: Then copy the Servlet class file to the classes folder in order to run the
Servlet that we created. All you need to do is copy the Servlet class file (the file we
obtained from Step 4) to this folder.
Step 9: Edit web.xml to include Servlet’s name and URL pattern. This step involves two
actions viz. including the Servlet’s name and then mentioning the url- pattern. Let us first
see as how to include the Servlet’s name in the web.xml file.
<web-app>
<servlet>
<servlet-name>MyServ</servlet-name>
<servlet-class>LifeCycle</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>MyServ</servlet-name>
<url-pattern>/lc</url-pattern>
</servlet-mapping>
</web-app>
CS -
Web Unit-
Note – The Servlet-name need not be the same as that of the class name. You can give a
different name (or alias) to the actual Servlet. This is one of the main reasons as why this
tag is used for. Next, include the url pattern using the <servlet-mapping> </servlet-
mapping> tag. The url pattern defines as how a user can access the Servlet from the
browser.
Step 10: Run Tomcat server and then execute your Servlet by opening any one of your
web browser and enter the URL as specified in the web.xml file. The complete URL that
needs to be entered in the browser is: http://localhost:8080/scce/lc
CS -
Web Unit-
ServletContext Enables servlets to log events and access info about their environment.
ServletRequest Used to read data from a client request.
ServletResponse Used to write data to a client response.
The following table summarizes the core classes that are provided in the javax.servlet package:
Class Description
GenericServlet Implements the Servlet and ServletConfig interfaces.
ServletInputStream Provides an input stream for reading requests from a client.
ServletOutputStream Provides an output stream for writing responses to a client.
ServletException Indicates a servlet error occurred.
UnavailableException Indicates a servlet is unavailable.
CS -
Web Unit-
CS -
Web Unit-
void setContentSize(int size) Sets the content length for the response to size.
void setContentType(String type) Sets the content type for the response to type.
CS -
Web Unit-
The following table summarizes the core classes that are provided in this package. The
most important of these is HttpServlet. Servlet developers typically extend this class in order to
process HTTP requests.
Class Description
Cookie Allows state information to be stored on a client machine.
HttpServlet Provides methods to handle HTTP requests and responses.
HttpSessionEvent Encapsulates a session-changed event.
HttpSessionBindingEvent Indicates when a listener is bound to or unbound from a session
value, or that a session attribute changed.
CS -
Web Unit-
summarizes the several methods of this class. All of these methods throw an
IllegalStateException if the session has already been invalidated.
Method Descrption
Object getAttribute(String attr) Returns the value associated with the name passed in
attr. Returns null if attr is not found.
long getCreationTime() Returns the time (in milliseconds since midnight,
January 1, 1970, GMT) when this session was created.
String getId() Returns the session ID.
void invalidate() Invalidates this session and removes it from the context.
void setAttribute(String s, Object val) Associates the value passed in val with the attribute
name passed in attr.
The following table summarizes the several important methods of the Cookie class:
String getComment() Returns the comment
String getDomain() Returns the domain
Int getMaxAge() Returns the age
String getName() Returns the name
String getPath() Returns the path
Boolean getSecure() Returns true if the cookie is secure
Int getVersion() Returns the version
Void setComment(String c) Sets the comment to c
Void setDomain(String d) Sets the domain to d
Void setPath(String p) Sets the path to p
Void setSecure(boolean Sets the security flag to secure
secure)
CS -
Web Unit-
Method Description
void doDelete(HttpServletRequest req, Handles an HTTP DELETE.
HttpServletResponse res) throws
IOException, ServletExcpetion
void doGet(HttpServletRequest req, Handles an HTTP GET.
HttpServletResponse res) throws
IOException, ServletExcpetion
void doPost(HttpServletRequest req, Handles an HTTP POST.
HttpServletResponse res) throws
IOException, ServletExcpetion
void doPut(HttpServletRequest req, Handles an HTTP PUT.
HttpServletResponse res) throws
IOException, ServletExcpetion
void doTrace(HttpServletRequest req, Handles an HTTP TRACE.
HttpServletResponse res) throws
IOException, ServletExcpetion
void service(HttpServletRequest req, Called by the server when an HTTP request for
HttpServletResponse res) throws this servlet. The arguments provide access to
IOException, ServletExcpetion the HTTP request and response, respectively.
Reading Parameters:
The parameters for the servlets can be read in one of the two ways. They are:
1) Initialized Parameters
2) Servlet Parameters
Reading Initialized Parameters:
The initialized parameters are the parameters which are initialized in the web.xml file and
they are not changeable in the entire servlet. These parameters are first written into the web.xml
file by using <init-param> tag. This tag contains two more sub tags: first, <param-name>, which
indicates the name of the parameter. Second tag is <param-value>, which contains the value for
the name given. The following example shows how the initialized parameters can be set and get
through servlets.
web.xml:
<web-app>
<servlet>
<servlet-name>InitParam</servlet-name>
<servlet-class> InitParamDemo</servlet-class>
<init-param>
<param-name>name</param-name>
<param-value>Ravi</param-value>
</init-param>
<init-param>
<param-name>class</param-name>
<param-value>ParamReadingDemo</param-value>
</init-param>
CS -
Web Unit-
</servlet>
<servlet-mapping>
<servlet-name> InitParam</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
InitParamDemo.java:
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class InitParamDemo extends HttpServlet
{
public void service(HttpServletRequest req, HttpServletResponse res) throws
IOException, ServletException
{
ServletConfig sc=getServletConfig();
res.setContentType("text/html");
PrintWriter out=res.getWriter();
out.println("Name: "+sc.getInitParameter("name")+"\n");
out.println("Class: "+sc.getInitParameter("class"));
}
}
Ouput:
LoginPage.html:
<html>
<head>
<title>Login Form</title>
<style type="text/css">
CS -
Web Unit-
body
{
text-align:center;
}
</style>
<body>
<form name="form1" action="LoginServlet" method="get">
<h1>Login Form</h1>
<table>
<tr>
<td>User Name:</td>
<td><input type="text" name="uname">
</td>
</tr>
<tr>
<td>Password:</td>
<td><input type="password" name="pwd">
</td>
</tr>
<tr>
<td><input type="submit" value="Login"></td>
<td><input type="reset" value="Clear"></td>
</tr>
</table>
</form>
</body>
</html>
LoginServlet.java:
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class LoginServlet extends HttpServlet
{
public void doGet(HttpServletRequest req,HttpServletResponse res) throws IOException,
ServletException
{
String name=req.getParameter("uname");
String pwd=req.getParameter("pwd");
res.setContentType("text/html");
PrintWriter out=res.getWriter();
if(name.equals("Chythu")&&pwd.equals("chythu536"))
{
out.println("Login Successfully Completed");
out.println("<b><br>");
out.println("Welcome Mr. "+name);
out.println("</b>");
CS -
Web Unit-
}
else
out.println("Login Failed");
out.close();
}
}
web.xml:
<web-app>
<servlet>
<servlet-name>LoginServ</servlet-name>
<servlet-class>LoginServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name> LoginServ </servlet-name>
<url-pattern>/LoginServlet</url-pattern>
</servlet-mapping>
</web-app>
GetFruit.html:
<html>
<head>
<title> Do Get Demo</title>
</head>
<body>
<form name="form1" action="Myserv1" method="get">
<b> Fruit</b>
<select name="fruit" >
<option value="banana"> Banana</option>
<option value="mango"> Mango</option>
<option value="orange"> Orange</option>
<option value="apple"> Apple</option>
CS -
Web Unit-
</select>
<input type="submit" value="submit">
</form>
</body>
</html>
The source code for FruitServlet.java is shown below. The doGet() method is
overridden to process any HTTP GET requests that are sent to this servlet. It uses the
getParameter() method of HttpServletRequest to obtain the selection that was made by the user.
A response is then formulated.
FruitServlet.java:
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class FruitServlet extends HttpServlet
{
public void doGet(HttpServletRequest req,HttpServletResponse res) throws IOException,
ServletException
{
String Fruit=req.getParameter("fruit");
res.setContentType("text/html");
PrintWriter out=res.getWriter();
out.println("you have selected fruit :" +Fruit);
out.close();
}
}
Compile the servlet. Next, copy the .class file the web application’s classes folder and
update the web.xml file. Then perform these steps to run this servlet.
1. Start Tomcat, if it is not already running.
2. Display the web page in a browser.
3. Select a fruit.
4. Submit the web page.
CS -
Web Unit-
CS -
Web Unit-
getParameter() method of HttpServletRequest to obtain the selection that was made by the user.
A response is then formulated.
FruitServlet.java:
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class FruitServlet extends HttpServlet
{
public void doPost(HttpServletRequest req,HttpServletResponse res) throws
IOException, ServletException
{
String Fruit=req.getParameter("fruit");
res.setContentType("text/html");
PrintWriter out=res.getWriter();
out.println("you have selected fruit :" +Fruit);
out.close();
}
}
Compile the servlet. Next, copy the .class file the web application’s classes folder and
update the web.xml file. Then perform these steps to run this servlet.
1. Start Tomcat, if it is not already running.
2. Display the web page in a browser.
3. Select a fruit.
4. Submit the web page.
Using Cookies:
A cookie is small amount information stored on a client machine and contains state
information. Cookies are valuable for tracking user activities. This example contains two files as
below:
CS -
Web Unit-
CookieDemo.html Allows a user to specify a value for the cookie named MyCookie.
CookieDemo.java Processes the submission of the CookieDemo.html.
CookieDemo.html:
<html>
<body>
<form name=”form1” method="post" action="CookieDemo">
<b>Enter the value for cookie</b>
<input type=text name="txt_data" size=30 value="">
<input type=submit value="Add Cookie”>
</form>
</body>
</html>
CookieDemo.java:
import java.io.*;
import javax.servlet.*;
import javax.servlet.http.*;
public class CookieDemo extends HttpServlet
{
public void doPost(HttpServletRequest req,HttpServletResponse res)throws
ServletException, IOException
{
String data=req.getParameter("txt_data");
Cookie cookie=new Cookie("Mycookie",data);
res.addCookie(cookie);
res.setContentType("text/html");
PrintWriter out=res.getWriter();
out.println("my cookie has been set to: ");
out.println(data);
out.println("<br>");
out.println("this page shows that cookie has been added");
out.close();
}
}
Compile the servlet. Next, copy the .class file the web application’s classes folder and
update the web.xml file. Then perform these steps to run this servlet.
1. Start Tomcat, if it is not already running.
2. Display the CookieDemo.html in a browser.
3. Enter a value for MyCookie.
4. Submit the web page.
CS -
Web Unit-
Session Tracking:
HTTP is a stateless protocol. Each request is independent of the previous one. However,
in some applications it is necessary to save state information so that information can be collected
from several interactions between a browser and a server. Sessions provide such a mechanism. A
session can be created via the getSession( ) method of the HttpServletRequest. An HttpSession
object is returned. This object can store a set of bindings that associate names with objects.
The setAttribute( ), getAttribute( ). getAttributeNames( ), and removeAttribute( )
methods of HttpSession manage these bindings. The following example illustrates how to use
session state. The getSession( ) method gets the current session. A new session is created if one
does not already exist. The getAttribute( ) method is called to obtain the object that is bound to
the name “cnt”.
Sessions.html:
<html>
<head>
<title>Session Demo</title>
</head>
<body>
<form name="form1" action="serv3" >
<b> Session Demo</b><br>
<input type="submit" value="Go to My Session Demo">
</form>
</body>
</html>
SessionDemo.java:
import java.io.*;
import javax.servlet.*;
import java.util.*;
import javax.servlet.http.*;
public class SessionDemo extends HttpServlet
{
CS -
Web Unit-
CS -
Web Unit-
JDBC Architecture:
The JDBC API supports both two-tier and three-tier processing models for database
access but in general, JDBC Architecture consists of two layers:
JDBC API: This provides the application-to-JDBC Manager connection.
JDBC Driver API: This supports the JDBC Manager-to-Driver Connection.
Above figure is the architectural diagram, which shows the location of the driver manager
with respect to the JDBC drivers and the Java application:
CS -
Web Unit-
The JDBC API uses a driver manager and database-specific drivers to provide transparent
connectivity to heterogeneous databases. The JDBC driver manager ensures that the correct
driver is used to access each data source. The driver manager is capable of supporting multiple
concurrent drivers connected to multiple heterogeneous databases.
CS -
Web Unit-
CS -
Web Unit-
Example:
Login.html:
<html>
<head>
<title>Login Form</title>
</head>
<body>
<center>
<h1>Login Form</h1>
<form action="login" method="post">
<table>
<tr>
<td>User name:</td>
<td><input type="text" name="uname"/></td>
</tr>
<tr>
<td>Password:</td>
<td><input type="password" name="pwd"/></td>
</tr>
<tr>
<td><input type="submit" value="Login"></td>
<td><input type="reset" value="Clear"/></td>
</tr>
</table>
</form>
</center>
</body>
</html>
LoginSrv.java:
import java.io.*;
import java.util.*;
import javax.servlet.*;
import javax.servlet.http.*;
import java.sql.*;
public class LoginSrv extends HttpServlet
{
public void doPost(HttpServletRequest request, HttpServletResponse response) throws
ServletException, IOException
{
try
{
response.setContentType("text/html");
PrintWriter out=response.getWriter();
String un=request.getParameter("uname");
String pwd=request.getParameter("pwd");
out.println("<head><title>SCCE</title></head>");
CS -
Web Unit-
Class.forName("com.mysql.jdbc.Driver");
Connection con=DriverManager.getConnection("jdbc:mysql://localhost:3306/scce", "root", "");
Statement stmt=con.createStatement();
ResultSet rs=stmt.executeQuery("select * from Login where uname='"+un+"' and
pwd='"+pwd+"'");
if(rs.next())
out.println("<h1>Welcome "+rs.getString(1)+", You are logged in successfully</h1>");
else
out.println("<h1>Login Failed</h1>");
}
catch(Exception se)
{
se.printStackTrace();
}
}
web.xml:
<web-app>
<servlet>
<servlet-name>LoginSrv</servlet-name>
<servlet-class>LoginSrv</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>LoginSrv</servlet-name>
<url-pattern>/login</url-pattern>
</servlet-mapping>
</web-app>
CS -
Web Unit-
UNIT-V
JAVA SERVER PAGES AND BEANS
The Problem with the Servlets:
In one and only one class, the servlet alone has to do various tasks such as,
Acceptance of request
Processing of request
Handling of business logic
Generation of response.
Hence there are some problems that are associated with the servlets-
1. For developing a servlet based application, knowledge of Java as well as HTML code is
necessary.
2. While developing any web based application, if a look and feel of the web based
application needs to be changed then the entire source code to be changed and
recompiled.
3. There are some web page development tools available using which the developer can
develop the web based applications. But the servlets do not support such tools. Even if
such tools are used for a servlet, we need to change the embedded HTML code manually,
which is a time consuming, error prone and complicated process.
Advantages of JSP:
Following is the list of other advantages of using JSP over other technologies:
1. Active Server Pages (ASP): The advantages of JSP are twofold. First, the dynamic part
is written in Java, not Visual Basic or other MS specific language, so it is more powerful
and easier to use. Second, it is portable to other operating systems and non-Microsoft
Web servers.
2. Pure Servlets: It is more convenient to write (and to modify!) regular HTML than to
have plenty of println statements that generate the HTML.
3. Server-Side Includes (SSI): SSI is really only intended for simple inclusions, not for
CS 14
Web Unit-
CS 14
Web Unit-
"real" programs that use form data, make database connections, and the like.
4. JavaScript: JavaScript can generate HTML dynamically on the client but can hardly
interact with the web server to perform complex tasks like database access and image
processing etc.
5. Static HTML: Regular HTML, of course, cannot contain dynamic information.
JSP Architecture:
The web server needs a JSP engine i.e., container to process JSP pages. The JSP
container is responsible for intercepting requests for JSP pages. A JSP container works with the
Web server to provide the runtime environment and other services a JSP needs. It knows how to
understand the special elements that are part of JSPs. Following diagram shows the position of
JSP container and JSP files in a Web Application.
CS 14
Web Unit-
JSP Processing:
The following steps explain how the web server creates the web page using JSP:
1. As with a normal page, your browser sends an HTTP request to the web server. The web
server recognizes that the HTTP request is for a JSP page and forwards it to a JSP engine.
This is done by using the URL or JSP page which ends with .jsp instead of .html.
2. The JSP engine loads the JSP page from disk and converts it into servlet content. This
conversion is very simple in which all template text is converted to println( ) statements
and all JSP elements are converted to Java code that implements the corresponding
dynamic behavior of the page.
3. The JSP engine compiles the servlet into an executable class and forwards the original
request to a servlet engine.
4. A part of the web server called the servlet engine loads the Servlet class and executes it.
During execution, the servlet produces an output in HTML format, which the servlet
engine passes to the web server inside an HTTP response.
5. The web server forwards the HTTP response to your browser in terms of static HTML
content.
6. Finally web browser handles the dynamically generated HTML page inside the HTTP
response exactly as if it were a static page.
Typically, the JSP engine checks whether a servlet for a JSP file already exists and
whether the modification date on the JSP is older than the servlet. If the JSP is older than its
generated servlet, the JSP container assumes that the JSP hasn't changed and that the generated
servlet still matches the JSP's contents. This makes the process more efficient than with other
scripting languages (such as PHP) and therefore faster. So in a way, a JSP page is really just
another way to write a servlet without having to be a Java programming wiz. Except for the
translation phase, a JSP page is handled exactly like a regular servlet. All the above mentioned
steps can be shown below in the following diagram:
CS 14
Web Unit-
The three major phases of JSP life cycle are very similar to Servlet Life Cycle and they are as
follows:
1. JSP Compilation:
When a browser asks for a JSP, the JSP engine first checks to see whether it needs to
compile the page. If the page has never been compiled, or if the JSP has been modified since it
was last compiled, the JSP engine compiles the page. The compilation process involves three
steps:
1. Parsing the JSP.
2. Turning the JSP into a servlet.
3. Compiling the servlet.
2. JSP Initialization:
When a container loads a JSP it invokes the jspInit() method before servicing any requests.
If you need to perform JSP-specific initialization, override the jspInit() method:
public void jspInit() {
// Initialization code...
}
Typically initialization is performed only once and as with the servlet init method, you generally
initialize database connections, open files, and create lookup tables in the jspInit method.
3. JSP Execution:
This phase of the JSP life cycle represents all interactions with requests until the JSP is
destroyed. Whenever a browser requests a JSP and the page has been loaded and initialized, the
JSP engine invokes the _jspService() method in the JSP. The _jspService() method takes an
HttpServletRequest and an HttpServletResponse as its parameters as follows:
CS 14
Web Unit-
CS 14
Web Unit-
The _jspService() method of a JSP is invoked once per a request and is responsible for
generating the response for that request and this method is also responsible for generating
responses to all seven of the HTTP methods ie. GET, POST, DELETE etc.
4. JSP Cleanup:
The destruction phase of the JSP life cycle represents when a JSP is being removed from use by
a container. The jspDestroy() method is the JSP equivalent of the destroy method for servlets.
Override jspDestroy when you need to perform any cleanup, such as releasing database
connections or closing open files. The jspDestroy() method has the following form:
JSP Elements:
Java Server Page is facilitated with three types of elements. They are as follows:
i) JSP Directives
ii) JSP Actions
iii) JSP Scripting Elements
1) JSP Directives:
JSP directives provide directions and instructions to the container, telling it how to handle
certain aspects of JSP processing. It usually has the following form:
<%@ directive attribute="value" %>
There are three types of directive tag are available in JSP:
CS 14
Web Unit-
Directive Description
Defines page-dependent attributes, such as scripting language,
<%@ page ... %>
error page, and buffering requirements.
<%@ include ... %> Includes a file during the translation phase.
<%@ taglib ... %> Declares a tag library, containing custom actions, used in the page.
CS 14
Web Unit-
CS 15
Web Unit-
Id attribute: The id attribute uniquely identifies the Action element, and allows the
action to be referenced inside the JSP page. If the Action creates an instance of an object
the id value can be used to reference it through the implicit object PageContext
Scope attribute: This attribute identifies the lifecycle of the Action element. The id
attribute and the scope attribute are directly related, as the scope attribute determines the
lifespan of the object associated with the id. The scope attribute has four possible values:
a) page
b) request
c) session, and
d) application
Example:
Let us define following two files: date.jsp and main.jsp as follows:
date.jsp:
<p>
Today's date: <%= (new java.util.Date()).toLocaleString()%>
</p>
main.jsp:
<html>
<head>
<title>The include Action Example</title>
</head>
<body>
<center>
<h2>The include action Example</h2>
<jsp:include page="date.jsp" flush="true" />
</center>
</body>
</html>
Now let us keep all these files in root directory and try to access main.jsp. This would
display result something like this:
The include action Example
Today's date: 12-Sep-2010 14:54:22
CS 15
Web Unit-
Here, the jsp:setProperty is executed only if a new object was instantiated, not if an
existing one was found. Following is the list of attributes associated with setProperty action:
Following is the list of required attributes associated with setProperty action:
Attribute Description
The name of the Bean that has a property to be retrieved. The
Name
Bean must have been previously defined.
The property attribute is the name of the Bean property to be
property
retrieved.
CS 15
Web Unit-
Example:
Let us define a test bean which we will use in our example:
TestBean.java:
package action;
public class TestBean
{
private String message = "No message specified";
public String getMessage()
{
return(message);
}
public void setMessage(String message)
{
this.message = message;
}
}
Compile above code to generated TestBean.class file and make sure that you copied
TestBean.class in C:\apache-tomcat-7.0.2\webapps\WEB-INF\classes\action folder and
CLASSPATH variable should also be set to this folder:
main.jsp:
<html>
<head>
<title>Using JavaBeans in JSP</title>
CS 15
Web Unit-
CS 15
Web Unit-
</head>
<body>
<center>
<h2>Using JavaBeans in JSP</h2>
<jsp:useBean id="test" class="action.TestBean" />
<jsp:setProperty name="test" property="message" value="Hello JSP..." />
<p>Got message. . .</p>
<jsp:getProperty name="test" property="message" />
</center>
</body>
</html>
Now try to access main.jsp, it would display following result:
CS 15
Web Technologies Unit-
Now let us keep all these files in root directory and try to access main.jsp. This would
display result something like as below. Here it discarded content from main page and displayed
content from forwarded page only.
Today's date: 12-Sep-2010 14:54:22
vi) The <jsp:plugin> Action:
The plugin action is used to insert Java components into a JSP page. It determines the
type of browser and inserts the <object> or <embed> tags as needed. If the needed plugin is not
present, it downloads the plugin and then executes the Java component. The Java component can
be either an Applet or a JavaBean. The plugin action has several attributes that correspond to
common HTML tags used to format Java components. The <param> element can also be used to
send parameters to the Applet or Bean. Following is the typical syntax of using plugin action:
<jsp:plugin type="applet" codebase="dirname" code="MyApplet.class" width="60"
height="80">
<jsp:param name="fontcolor" value="red" />
<jsp:param name="background" value="black" />
<jsp:fallback>
Unable to initialize Java Plugin
</jsp:fallback>
</jsp:plugin>
You can try this action using some applet if you are interested. A new element, the
<fallback> element, can be used to specify an error string to be sent to the user in case the
component fails.
i) The Scriptlet:
A scriptlet can contain any number of JAVA language statements, variable or method
declarations, or expressions that are valid in the java server page scripting language. Following is
the syntax of Scriptlet:
<% code fragment %>
Any text, HTML tags, or JSP elements you write must be outside the scriptlet. Following
is the simple example for JSP:
<html>
<body>
<%
out.println("Your IP address is " + request.getRemoteAddr());
%>
</body>
</html>
CS 15
Web Technologies Unit-
ii) Declarations:
A declaration declares one or more variables or methods that you can use in Java code
later in the JSP file. You must declare the variable or method before you use it in the JSP file.
Following is the syntax of JSP Declarations:
<%! declaration; [ declaration; ] ... %>
Following is the simple example for JSP Comments:
<%! int i = 0; %>
<%! int a, b, c; %>
<%! Circle a = new Circle(2.0); %>
iii) Expressions:
A JSP expression element contains a scripting language expression that is evaluated,
converted to a String, and inserted where the expression appears in the JSP file. Because the
value of an expression is converted to a String, you can use an expression within a line of text,
whether or not it is tagged with HTML, in a JSP file. The expression element can contain any
expression that is valid according to the Java Language Specification but you cannot use a
semicolon to end an expression. Following is the syntax of JSP Expression:
iv) Comments:
JSP comment marks text or statements that the JSP container should ignore. A JSP
comment is useful when you want to hide or "comment out" part of your JSP page.
Following is the syntax of JSP comments:
<%--This is JSP comment --%>
Following is the simple example for JSP Comments:
<html>
<head>
<title>A Comment Test</title>
</head>
<body>
<h2>A Test of Comments</h2>
CS 15
Web Technologies Unit-
CS 15
Web Technologies Unit-
of the page directive. The JspWriter object contains most of the same methods as the
java.io.PrintWriter class. However, JspWriter has some additional methods designed to deal with
buffering. Unlike the PrintWriter object, JspWriter throws IOExceptions. Following are the
important methods which we would use to write boolean char, int, double, object, String etc.
Method Description
out.print(dataType dt) Print a data type value
Print a data type value then terminate the line with new line
out.println(dataType dt)
character.
out.flush() Flush the stream.
CS 15
Web Technologies Unit-
Example:
CounterDemo.java:
public class CounterDemo
{
public int cnt;
public CounterDemo()
{
cnt=0;
}
public int getCnt( )
{
return cnt;
}
public void setCnt(int cnt)
{
this.cnt=cnt;
}
}
beanJSP.jsp:
<html>
<head>
<title>Using beans in JSP</title>
</head>
<body>
<jsp:useBean id=“bean1” class=“CounterDemo” scope=“session” />
<%
bean1.setCnt(bean1.getCnt( )+1);
%>
Your count is: <%=bean1.getCnt( )%>
</body>
</html>
CS 16
Web Technologies Unit-
Using Cookies:
Cookies are text files stored on the client computer and they are kept for various
information tracking purposes. JSP transparently supports HTTP cookies using underlying
servlet technology.
There are three steps involved in identifying returning users:
Server script sends a set of cookies to the browser. For example name, age, or
identification number etc.
Browser stores this information on local machine for future use.
When next time browser sends any request to web server then it sends those cookies
information to the server and server uses that information to identify the user or may be
for some other purpose as well.
7 public String getValue() This method gets the value associated with the cookie.
8 public void setPath(String uri) This method sets the path to which this cookie
applies. If you don't specify a path, the cookie is returned for all URLs in the same
directory as the current page as well as all subdirectories.
9 public String getPath() This method gets the path to which this cookie applies.
public void setSecure(boolean flag) This method sets the boolean value indicating
10
whether the cookie should only be sent over encrypted (i.e. SSL) connections.
public void setComment(String purpose) This method specifies a comment that
11
describes a cookie's purpose. The comment is useful if the browser presents the
cookie
CS 16
Web Technologies Unit-
to the user.
public String getComment()This method returns the comment describing the
12
purpose of this cookie, or null if the cookie has no comment.
Example:
The following example illustrates how to create cookies and how to use them for processing.
This example contains three files:
CookieDemo.html – This file allow us to enter name and value for cookie we want to create.
CookieDemo.jsp – This file process the input from the CookieDemo.html file.
CookieDisp.jsp – This file displays the created cookies.
CookieDemo.html:
<html>
<head>
<title>Cookie Demo</title>
</head>
<body><br>
<center>
<h1>Cookie Demo</h1>
<form action="CookieDemo.jsp" method="get">
<table>
<tr>
<td>Enter Cookie Name:</td>
<td><input type="text" name="cname"></td>
</tr>
<tr>
<td>Enter Cookie Value:</td>
<td><input type="text" name="cvalue"></td>
</tr>
<tr>
<td align="center"><input type="submit" value="Submit"
name="submit"></td>
</tr>
</table>
</form>
</center>
</body>
</html>
CS 16
Web Technologies Unit-
CookieDemo.jsp:
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Cookie Demo</title>
</head>
<body>
<center>
<%
String cn=request.getParameter("cname");
String cv=request.getParameter("cvalue");
Cookie c=new Cookie (cn,cv);
response.addCookie(c);
c.setMaxAge(50*50);
%>
<h1>Cookie Added</h1>
<form method="get" action="CookieDisp.jsp">
<input type="submit" value="List Cookies">
</form>
</center>
</body>
</html>
CookieDisp.html:
<%@page contentType="text/html" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Cookie Display</title>
</head>
<body>
<center>
<h1>Cookies List</h1>
<%
Cookie[] c=request.getCookies();
%>
<table border=1>
<tr>
CS 16
Web Technologies Unit-
<%
out.println("<td><b> Cookie Name </td> <td> <b>Cookie value</b>
</td>");
for(int i=0;i<c.length;i++)
{
out.println("<h2> <tr> <td>
"+c[i].getName()+"</td><td>"+c[i].getValue()+"</td></tr>");
}
%>
</tr>
</table>
</center>
</body>
</html>
Using Sessions:
JSP makes use of servlet provided HttpSession Interface which provides a way to identify
a user across more than one page request or visit to a Web site and to store information about
that user. By default, JSPs have session tracking enabled and a new HttpSession object is
instantiated for each new client automatically. Disabling session tracking requires explicitly
turning it off by setting the page directive session attribute to false as follows:
<%@ page session="false" %>
The JSP engine exposes the HttpSession object to the JSP author through the implicit
session object. Since session object is already provided to the JSP programmer, the programmer
can immediately begin storing and retrieving data from the object without any initialization or
getSession(). Here is a summary of important methods available through session object:
S.N. Method & Description
public Object getAttribute(String name) This method returns the object
1 bound with the specified name in this session, or null if no object is bound under
the name.
public String getId() This method returns a string containing the unique
4
identifier assigned to this session.
CS 16
Web Technologies Unit-
public long getLastAccessedTime() This method returns the last time the client
5 sent a request associated with this session, as the number of milliseconds since
midnight January 1, 1970 GMT.
public int getMaxInactiveInterval() This method returns the maximum time
6 interval, in seconds, that the servlet container will keep this session open
between client accesses.
public void invalidate() This method invalidates this session and unbinds any
7
objects bound to it.
public boolean isNew( This method returns true if the client does not yet know
8
about the session or if the client chooses not to join the session.
Example:
The following example illustrates how to use session state. A new session is created if
one does not already exist. The getAttribute( ) method is called to obtain the object that is
bound to the name “cnt”.
Sessions.html:
<html>
<head>
<title>Session Demo</title>
</head>
<body>
<form name="form1" action="SessionDemo.jsp" >
<b> Session Demo</b><br>
<input type="submit" value="Go to My Session Demo">
</form>
</body>
</html>
SessionDemo.jsp:
<%@ page import = “java.util.*” %>
<%
String heading;
Integer cnt=(Integer)session.getAttribute("cnt");
if(cnt==null)
{
CS 16
Web Technologies Unit-
cnt=new Integer(0);
heading="Welcome for the first time";
}
else
{
heading="Welcome once again";
cnt=new Integer(cnt.intValue()+1);
}
session.setAttribute("cnt",cnt);
out.println("<html>");
out.println("<body>");
out.println("<h1>"+heading);
out.println("The number of previous accesses: "+cnt);
out.println("</body>");
out.println("</html>");
%>
Login.html:
<html>
<head>
<title>Login Page</title>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>
<center>
<h1>Login Form</h1>
<form action="Login.jsp" method="post">
<table>
<tr>
<td>User name:</td>
<td><input type="text" name="uname"/></td>
</tr>
<tr>
<td>Password:</td>
<td><input type="password" name="pwd"/></td>
</tr>
<tr>
<td><input type="submit" value="Login"></td>
<td><input type="reset" value="Clear"/></td>
CS 16
Web Technologies Unit-
</tr>
</table>
</form>
</center>
</body>
</html>
Login.jsp:
<%@page language="java" import="java.sql.*" %>
<%
String
un=request.getParameter("uname");
String pwd=request.getParameter("pwd");
Class.forName("com.mysql.jdbc.Driver");
""); Connection con=DriverManager.getConnection("jdbc:mysql://localhost:3306/scce", "root",
Statement stmt=con.createStatement();
out.println("<head><title>Login Page</title></head>");
ResultSet rs=stmt.executeQuery("select * from Login where uname='"+un+"' and
pwd='"+pwd+"'");
if(rs.next())
out.println("<h1>Welcome "+rs.getString(1)+", You are logged in successfully</h1>");
else
out.println("<h1>Login Failed</h1>");
%>
INTRODUCTION:
Software components are self-contained software units developed according to the motto
“Developed them once, run and reused them everywhere”. Or in other words, reusability is the
main concern behind the component model. A software component is a reusable object that can
be plugged into any target software application. You can develop software components using
various programming languages, such as C, C++, Java, and Visual Basic.
A “Bean” is a reusable software component model based on sun’s java bean
specification that can be manipulated visually in a builder tool.
The term software component model describe how to create and use reusable
software components to build an application
Builder tool is nothing but an application development tool which lets you both to
create new beans or use existing beans to create an application.
To enrich the software systems by adopting component technology JAVA came up
with the concept called Java Beans.
Java provides the facility of creating some user defined components by means of
Bean programming.
We create simple components using java beans.
We can directly embed these beans into the software.
ADVANTAGES OF JAVA BEANS:
The java beans posses the property of “Write once and run anywhere”.
Beans can work in different local platforms.
Beans have the capability of capturing the events sent by other objects and vice versa
CS 16
Web Technologies Unit-
CS 16
Web Technologies Unit-
display size.
ii) Methods
Same as normal Java methods.
Every property should have accessor (get) and mutator (set) method.
All Public methods can be identified by the introspection mechanism.
There is no specific naming standard for these methods.
iii) Events:
It is similar to Swing/AWT event handling.
THE JAVABEAN COMPONENT SPECIFICATION:
i) Customization:
It is the ability of JavaBean to allow its properties to be changed in build and execution phase.
ii) Persistence:
It is the ability of JavaBean to save its state to disk or storage device and restore the saved state
when the JavaBean is reloaded.
iii) Communication:
It is the ability of JavaBean to notify change in its properties to other JavaBeans or the container.
iv) Introspection:
It is the ability of a JavaBean to allow an external application to query the properties, methods, and
events supported by it.
SERVICES OF JAVABEAN COMPONENTS:
i) Builder support:
It enables you to create and group multiple JavaBeans in an application.
ii) Layout:
It allows multiple JavaBeans to be arranged in a development environment.
iii) Interface publishing:
It enables multiple JavaBeans in an application to communicate with each other.
iv) Event handling:
It refers to firing and handling of events associated with a JavaBean.
v) Persistence:
It enables you to save the last state of JavaBean.
FEATURES OF A JAVABEAN:
Support for “introspection” so that a builder tool can analyze how a bean works.
Support for “customization” to allow the customization of the appearance and behavior of
a bean.
Support for “events” as a simple communication metaphor than can be used to connect
up beans.
Support for “properties”, both for customization and for programmatic use.
Support for “persistence”, so that a bean can save and restore its customized state.
CS 16
Web Technologies Unit-
CS 17
Web Technologies Unit-
ii) BeanBox Window: It is a workspace for creating the layout of JavaBean application.
The following figure shows the BeanBox window:
iii) Properties Window: It displays all the exposed properties of a JavaBean. You
can modify JavaBean properties in the properties window.
The following figure shows the Properties window:
CS 17
Web Technologies Unit-
iv) Method Tracer window: It displays the debugging messages and method calls for a
JavaBean application.
The following figure shows the Method Tracer window:
CS 17
Web Technologies Unit-
setBackground(Color.green);
}
}
3. Compile the source file(s)
C:\Beans >Javac MyBean.java
4. Create a manifest file
The manifest file for a JavaBean application contains a list of all the class files that
make up a JavaBean.
The entry in the manifest file enables the target application to recognize the
JavaBean classes for an application.
For example, the entry for the MyBean JavaBean in the manifest file is as shown:
Manifest-Version:
1.0 Name:
Note: write that MyBean.class Java- as MyBean.mft
2 lines code in the notepad and save that
The rules to create a manifest file are:
Press the Enter key after typing each line in the manifest file.
Leave a space after the colon.
Type a hyphen between Java and Bean.
No blank line between the Name and the Java-Bean entry.
5. Generate a JAR file
Syntax for creating jar file using manifest file C:\
Beans >jar cfm MyBean.jar MyBean.mf MyBean.class
JAR file:
JAR file allows you to efficiently deploy a set of classes and their associated resources.
JAR file makes it much easier to deliver, install, and download. It is compressed.
Java Archive File
The files of a JavaBean application are compressed and grouped as JAR files to reduce
the size and the download time of the files.
The syntax to create a JAR file from the command prompt is:
jar <options> <file_names>
The file_names is a list of files for a JavaBean application that are stored in the JAR file.
The various options that you can specify while creating a JAR file are:
c: Indicates the new JAR file is created.
f: Indicates that the first file in the file_names list is the name of the JAR file.
m: Indicates that the second file in the file_names list is the name of the manifest file.
t: Indicates that all the files and resources in the JAR file are to be displayed in a
tabular format.
v: Indicates that the JAR file should generate a verbose output.
x: Indicates that the files and resources of a JAR file are to be extracted.
o: Indicates that the JAR file should not be compressed.
m: Indicates that the manifest file is not created.
6. Start BDK
CS 17
Web Technologies Unit-
Go to-> C:\bdk1_1\beans\
beanbox
Click on run.bat file. When we click on run.bat file the BDK software automatically started.
7. Load Jar file
Go to
Beanbox->File->Load jar. Here we have to select our created jar file when we click on ok, our
bean (user-defined) MyBean appear in the ToolBox.
8. Test our created user defined bean
Select the MyBean from the ToolBox when we select that bean one + simple appear then drag
that Bean in to the Beanbox. If you want to apply events for that bean, now we apply the events
for that Bean.
CS 17