Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
What is JavaScript ?
JavaScript started life as LiveScript, but Netscape changed the name, possibly because of the
excitement being generated by Java.to JavaScript. JavaScript made its first appearance in
Netscape 2.0 in 1995 with a name LiveScript.
The general-purpose core of the language has been embedded in Netscape, Internet Explorer,
and other web browsers.
JavaScript is:
JavaScript Syntax
A JavaScript consists of JavaScript statements that are placed within the <script>... </script> HTML tags
in a web page.
You can place the <script> tag containing your JavaScript anywhere within you web page but it is
preferred way to keep it within the <head> tags.
The <script> tag alert the browser program to begin interpreting all the text between these tags as a
script. So simple syntax of your JavaScript will be as follows
<script ...>
JavaScript code
</script>
language: This attribute specifies what scripting language you are using. Typically, its value will be
javascript. Although recent versions of HTML (and XHTML, its successor) have phased out the use of this
attribute.
type: This attribute is what is now recommended to indicate the scripting language in use and its value
should be set to "text/javascript".
JavaScript
<html>
<body>
<script language="javascript" type="text/javascript">
<!--
document.write("Hello World!")
//-->
</script>
</body>
</html>
We added an optional HTML comment that surrounds our Javascript code. This is to save our code from
a browser that does not support Javascript. The comment ends with a "//-->". Here "//" signifies a
comment in Javascript, so we add that to prevent a browser from reading the end of the HTML
comment in as a piece of Javascript code.
JavaScript DataTypes:
One of the most fundamental characteristics of a programming language is the set of data types it
supports. These are the type of values that can be represented and manipulated in a programming
language.
Before you use a variable in a JavaScript program, you must declare it. Variables are declared with the
var keyword as follows:
<script type="text/javascript">
<!--
var money;
var name;
//-->
</script>
JavaScript
For instance, you might create variable named money and assign the value 2000.50 to it later. For
another variable you can assign a value the time of initialization as follows:
<script type="text/javascript">
<!--
var name = "Ali";
var money;
money = 2000.50;
//-->
</script>
JavaScript Operators
What is an operator?
Simple answer can be given using expression 4 + 5 is equal to 9. Here 4 and 5 are called operands and +
is called operator. JavaScript language supports following type of operators.
Arithmetic Operators
Comparision Operators
Logical (or Relational) Operators
Assignment Operators
Conditional (or ternary) Operators
Simple assignment operator, Assigns values from right C = A + B will assigne value of A + B
=
side operands to left side operand into C
JavaScript supports conditional statements which are used to perform different actions based on
different conditions. Here we will explain if..else statement.
if statement
if...else statement
if...else if... statement.
if statement:
The if statement is the fundamental control statement that allows JavaScript to make decisions and
execute statements conditionally.
Syntax:
if (expression){
Statement(s) to be executed if expression is true
}
Here JavaScript expression is evaluated. If the resulting value is true, given statement(s) are executed. If
expression is false then no statement would be not executed. Most of the times you will use comparison
operators while making decisions.
Example:
<script type="text/javascript">
<!--
var age = 20;
if( age > 18 ){
document.write("<b>Qualifies for driving</b>");
}
//-->
</script>
if...else statement:
The if...else statement is the next form of control statement that allows JavaScript to execute
statements in more controlled way.
Syntax:
if (expression){
Statement(s) to be executed if expression is true
}else{
Statement(s) to be executed if expression is false
}
Here JavaScript expression is evaluated. If the resulting value is true, given statement(s) in the if block,
are executed. If expression is false then given statement(s) in the else block, are executed.
JavaScript
Example:
<script type="text/javascript">
<!--
var age = 15;
if( age > 18 ){
document.write("<b>Qualifies for driving</b>");
}else{
document.write("<b>Does not qualify for driving</b>");
}
//-->
</script>
Syntax:
if (expression 1){
Statement(s) to be executed if expression 1 is true
}else if (expression 2){
Statement(s) to be executed if expression 2 is true
}else if (expression 3){
Statement(s) to be executed if expression 3 is true
}else{
Statement(s) to be executed if no expression is true
}
There is nothing special about this code. It is just a series of if statements, where each if is part of the
else clause of the previous statement. Statement(s) are executed based on the true condition, if non of
the condition is true then else block is executed.
Example:
<script type="text/javascript">
<!--
var book = "maths";
if(book == "history" ){
document.write("<b>History Book</b>");
}else if( book == "maths" ){
document.write("<b>Maths Book</b>");
}else if( book == "economics" ){
document.write("<b>Economics Book</b>");
}else{
document.write("<b>Unknown Book</b>");
}
//-->
</script>
JavaScript
Maths Book
The loop initialization where we initialize our counter to a starting value. The initialization
statement is executed before the loop begins.
The test statement which will test if the given condition is true or not. If condition is true then
code given inside the loop will be executed otherwise loop will come out.
The iteration statement where you can increase or decrease your counter.
You can put all the three parts in a single line separated by a semicolon.
Syntax:
for (initialization; test condition; iteration statement){
Statement(s) to be executed if test condition is true
}
Example:
Following example illustrates a basic for loop:
<script type="text/javascript">
<!--
var count;
document.write("Starting Loop" + "<br />");
for(count = 0; count < 10; count++){
document.write("Current Count : " + count );
document.write("<br />");
}
document.write("Loop stopped!");
//-->
</script>
Starting Loop
Current Count : 0
Current Count : 1
Current Count : 2
Current Count : 3
Current Count : 4
Current Count : 5
Current Count : 6
Current Count : 7
Current Count : 8
Current Count : 9
Loop stopped!
JavaScript Functions
Before we use a function we need to define that function. The most common way to define a function in
JavaScript is by using the function keyword, followed by a unique function name, a list of parameters
(that might be empty), and a statement block surrounded by curly braces. The basic syntax is shown
here:
<script type="text/javascript">
<!--
function functionname(parameter-list)
{
statements
}
//-->
</script>
Example:
A simple function that takes no parameters called sayHello is defined here:
<script type="text/javascript">
<!--
function sayHello()
{
alert("Hello there");
}
//-->
</script>
Calling a Function:
To invoke a function somewhere later in the script, you would simple need to write the name of that
function as follows:
<script type="text/javascript">
<!--
sayHello();
//-->
</script>
JavaScript
Function Parameters:
Till now we have seen function without a parameters. But there is a facility to pass different parameters
while calling a function. These passed parameters can be captured inside the function and any
manipulation can be done over those parameters.
Example:
Let us do a bit modification in our sayHello function. This time it will take two parameters:
<script type="text/javascript">
<!--
function sayHello(name, age)
{
alert( name + " is " + age + " years old.");
}
//-->
</script>
Note: We are using + operator to concatenate string and number all together. JavaScript does not mind
in adding numbers into strings.
<script type="text/javascript">
<!--
sayHello('Zara', 7 );
//-->
</script>
For example you can pass two numbers in a function and then you can expect from the function to
return their multiplication in your calling program.
Example:
This function takes two parameters and concatenates them and return resultant in the calling program:
<script type="text/javascript">
<!--
function concatenate(first, last)
{
var full;
<script type="text/javascript">
<!--
var result;
result = concatenate('Zara', 'Ali');
alert(result );
//-->
</script>
JavaScript Events
JavaScript's interaction with HTML is handled through events that occur when the user or browser
manipulates a page.
When the page loads, that is an event. When the user clicks a button, that click, too, is an event.
Another example of events are like pressing any key, closing window, resizing window etc.
Developers can use these events to execute JavaScript coded responses, which cause buttons to close
windows, messages to be displayed to users, data to be validated, and virtually any other type of
response imaginable to occur.
Example:
<html>
<head>
<script type="text/javascript">
<!--
function sayHello() {
alert("Hello World");
}
//-->
</script>
</head>
<body>
<input type="button" onclick="sayHello();" value="Say Hello" />
</body>
</html>
Here is simple example showing its usage. Here we are calling a validate() function before submitting a
form data to the webserver. If validate() function returns true the form will be submitted otherwise it
will not submit the data.
Example:
<html>
<head>
<script type="text/javascript">
<!--
function validation() {
all validation goes here
.........
return either true or false
}
//-->
</script>
</head>
<body>
<form method="POST" action="t.cgi" onsubmit="return validate()">
.......
<input type="submit" value="Submit" />
</form>
</body>
</html>
Example:
Following
<html> example shows how a division reacts when we bring our mouse in that division:
<head>
<script type="text/javascript">
<!--
function over() {
alert("Mouse Over");
}
function out() {
alert("Mouse Out");
}
//-->
</script>
</head>
<body>
<div onmouseover="over()" onmouseout="out()">
<h2> This is inside the division </h2>
</div>
</body>
</html>
JavaScript
The standard HTML 4 events are listed here for your reference. Here script indicates a Javascript
function to be executed agains that event.
onmouseout script Script runs when mouse pointer moves out of an element
onmouseover script Script runs when mouse pointer moves over an element
<head>
<script type="text/javascript">
<!--
alert("Warning Message");
//-->
</script>
</head>
Nonetheless, an alert box can still be used for friendlier messages. Alert box gives only one button "OK"
to select and proceed.
If the user clicks on OK button the window method confirm() will return true. If the user clicks on the
Cancel button confirm() returns false. You can use confirmation dialog box as follows:
<head>
<script type="text/javascript">
<!--
var retVal = confirm("Do you want to continue ?");
if( retVal == true ){
alert("User wants to continue!");
return true;
}else{
alert("User does not want to continue!");
return false;
}
//-->
</script>
</head>
This method is one of the most common methods in the HTML DOM, and is used almost every time you
want to manipulate, or get info from, an element on your document.
Returns undefined if more than one element with the specified ID exists.
JavaScript
Syntax
document.getElementById(elementID)
document.getElementsByName()
The getElementsByName() method accesses all elements with the specified name.
Syntax
document.getElementsByName(name)
The value property contains the default value OR the value a user types in (or a value set by a script).
Syntax
Set the value property:
Object.value="text"
Object.value
JavaScript
Syntax
HTMLElementObject.innerHTML=text
Example:
Following
<html> example shows how a division reacts when we bring our mouse in that division:
<head>
<script type="text/javascript">
function changeLink()
{
document.getElementById('myAnchor').innerHTML="Hotcourses Abroad";
document.getElementById('myAnchor').href="http://www.hotcoursesabroad.com";
document.getElementById('myAnchor').target="_blank";
}
</script>
</head>
<body>
<a id="myAnchor" href="http://www.hotcourses.com">Hotcourses</a>
<input type="button" onclick="changeLink()" value="Change link">
</body>
</html>
Syntax
string.length
Example:
Following
<scriptexample shows how a division reacts when we bring our mouse in that division:
type="text/javascript">
var txt = "Hello World!";
document.write(txt.length);
</script>
Syntax
string.split(separator,limit);
Example:
Following
<scriptexample shows how a division reacts when we bring our mouse in that division:
type="text/javascript">
var date = "08/27/2013";
var n=str.split("/");
</script>
Syntax
string.indexOf(searchvalue,start)
Example:
Following
<scriptexample shows how a division reacts when we bring our mouse in that division:
type="text/javascript">
var str="Hello world, welcome to Hotcourses.";
var n=str.indexOf("t");
</script>
JavaScript
Example:
Following example
var mycars = shows how a division reacts when we bring our mouse in that division:
new Array();
mycars[0] = "Saab";
mycars[1] = "Volvo";
mycars[2] = "BMW";
Create an Array
An array can be created in three ways.
1: Regular:
Following example shows
var myCars=new how a division reacts when we bring our mouse in that division:
Array();
myCars[0]="Saab";
myCars[1]="Volvo";
myCars[2]="BMW";
2: Condensed:
Following example shows
var myCars=new how a division reacts when we bring our mouse in that division:
Array("Saab","Volvo","BMW");
3: Literal:
Following example shows how a division reacts when we bring our mouse in that division:
var myCars=["Saab","Volvo","BMW"];
Example:
Following example shows how a division reacts when we bring our mouse in that division:
var btn=document.createElement("BUTTON");
var t=document.createTextNode("CLICK ME");
btn.appendChild(t);
JavaScript
Syntax:
Following example shows how a division reacts when we bring our mouse in that division:
document.createElement(nodename)
RegExp Object
A regular expression is an object that describes a pattern of characters.
Regular expressions are used to perform pattern-matching and "search-and-replace" functions on text.
Modifiers
Modifier Description
g Perform a global match (find all matches rather than stopping after the
first match)
Brackets
Expression Description
Metacharacters
Metacharacter Description
\d Find a digit
Quantifiers
Quantifier Description
Property Description
constructor Returns the function that created the RegExp object's prototype
Method Description
var re = /\S+@\S+\.\S+/;
alert(re.test(email));