INTRODUCTION TO JAVASCRIPT
PROGRAMMING AND SCRIPTING LANGUAGES
JavaScript is sometimes referred to as a programming language, but it is really more accurate to call it a scripting language. The difference between the two is subtle. In both types of languages, the source code must be converted to machine language in order for the program to run. In programming languages, the process is performed by a piece of software called a compiler and is completed before the program runs. Once the compilation is completed, the program can be run without opening it within another program. In scripting languages, the source code is processed by the target program, which for HTML is the Web browser. When the document contains embedded JavaScript code, that code is interpreted by the browser and converted to machine language one line at a time that occurs automatically at run time, in a process called interpretation. The Web browser acts as interpreter software.
THE POWER OF JAVASCRIPT IN WEBPAGES
Under normal conditions, the output of a JavaScript function will be nothing more than one or perhaps several strings of text that are inserted into the host Web page. The resulting HTML page is then processed by the browser just as it would be if it had been keyed into the source document. The real power of embedding JavaScript code into a Web page comes from the fact that the resulting text can change from one day to the next, or even from one minute to the next. It is entirely possible for one person to enter a particular URL into his Web browser and see a Web page that is completely different from the page that is seen by another person who enters the exact same URL. These different Web pages could be the result of differences in time, location, or Web browsers. JavaScript is capable of detecting various conditions in the current operating environment, reacting accordingly.
JAVASCRIPT PROCESSING
In order for the Web browser to detect if a particular HTML page contains embedded JavaScript, the <script</script> tags are required. The Web browser interprets everything between these two tags as JavaScript source code instead of the standard HTML text. The browser will then convert the script (interpretation process) into binary code. This code will be executed and its output (if any) will be inserted into the HTML text stream and displayed as if it had been typed into the original HTML document. After the browser has finished processing the HTML document, the end result is that the script tags and everything in between will be stripped out of the page and replaced by whatever the output (result) is from the interpretation of the JavaScript. Also, any HTML formatting tags you put before or after the script tags will be processed just as they would be in a page without any embedded JavaScript code.
JAVASCRIPT SYNTAX
You need to understand that the scripts embedded between the script tags must conform to certain rules of grammar, called program syntax. JavaScript is made up of keywords, operators, and objects with properties and methods. Keywords are recognized as part of the language definition, are reserved by the language and cannot be used as a variable. The primary purpose of JavaScript is to generate text that will be inserted into the standard HTML text stream and contains a number of invisible entities call objects with well-defined sets of capabilities, which are accessed through methods (functions) within the objects. The programmer invokes the services of methods by keying the name of the object, followed by a period (“dot”, also known as the dot operator), and followed by the method name. Methods are followed by a parameter list enclosed in parentheses (sometimes the parentheses are empty). The parameter list provides the method with the information it needs to perform its function correctly. Each JavaScript statement is followed by a semicolon (;). Here is an example the syntax of an object, method, and parameter list:
document.write(“A string of text.”);
HTML WITHIN JAVASCRIPTS
Since the code between the script tags must conform to strict syntax, you cannot simply use HTML tags between the script tags. If you do this, the browser will not know how to interpret the code and give an error message. If it is necessary to use HTML tags inside a script, you must enclose the HTML tags in double quotes (“ ”), making it part of the output text stream. An example of this is:
document.write("<b<i>Good Morning</i</b<br />
<font color=’red’>Welcome To My Website!</font>");
CONDITIONAL STATEMENTS
One of the most powerful features of the JavaScript language is the conditional statement. This ability to make decisions is common among all programming languages and gives programmers the ability to evaluate a specific condition and then perform different actions depending on the results of that evaluation. Just like JavaScript objects contain special functions called methods that perform various tasks, they can also contain properties that programmers can access to obtain information about the objects. The property of an object can be evaluated (used as part of the condition) to make decisions. The syntax for accessing a property is the object name, then a dot operator, followed by the property name. One of the properties that can be accessed is the appName property of the navigator object. This allows the program to determine the name of the Web browser currently being used. Example:
navigator.appName
The syntax of the conditional statement in JavaScript is very important. It begins with the keyword ‘if’, and then a condition is specified within a pair of parentheses. The condition is followed by a statement block that consists of an opening brace ({), one or more JavaScript statements, and then a closing brace (}). The opening brace indicates the beginning of a statement block and the closing brace marks the end of that block. It is necessary to carefully code these braces, because if the number of opening braces does not match the number of closing braces, it can cause serious problems in the program and will result in syntax errors. Note the placement of the braces in the following syntax shell of a JavaScript conditional statement:
if (<condition>)
{
statement i1;
statement i2;
statement i3;
.
.
.
statement iN;
}
else
{
statement e1;
statement e2;
statement e3;
.
.
.
statement eN;
}
The ‘else’ clause is optional, and defines the action to take if the specified condition is not true. The ‘else’ keyword appears immediately after the statement of the ‘if’ clause, and it is accompanied by a statement block of its own. Some rules for avoiding problems with braces are:
- Always place the opening brace directly below the keyword to which is belongs.
- Always indent the statements contained within the statement block.
- Always place the closing brace so that it is vertically aligned with its corresponding opening brace.
The condition part of the syntax (<condition>) in JavaScript will always consist of two tokens separated by a relational operator. A token can either be a variable name or a literal constant. The relational operator can be any of the following symbols:
OPERATOR / MEANING== / is equal to
!= / is not equal to
is less than
is greater than
<= / is less than or equal to
>= / is greater than or equal to
By using an object property in the condition with a relational operator and a literal, you can create a conditional statement to evaluate whether a particular property meets a certain condition. For example:
if (navigator.appName==”Netscape”)
{
document.write(“You are using Netscape Navigator”);
}
else
{
document.write(“You are not using Netscape Navigator”);
}
Once a condition has been evaluated, either the ‘if’ statement block or the ‘else’ statement block will be executed, but not both. If the result of the condition is true, the ‘if’ statement block will be executed and if it is false, the ‘else’ statement block will be executed.
COMMUNICATING WITH THE USER IN JAVASCRIPT
The most common way to communicate with user in JavaScript is to use the document.write() method. Another method to get the user’s attention is to use the alert() method. Its purpose is to display a special dialog box to alert the user that an expected event has occurred or some kind of user input is required. It is normally used when the user needs to be made aware of some unexpected error condition that has occurred. It can also be used when the program needs some kind of user acknowledgement before proceeding. This method is part of the interpreter itself and interacts directly with the underlying operating system. For this reason, it is not necessary to include the object name and dot operator. Example:
alert(“Netscape Navigator detected”);
Another way of providing information to the user is through accessing the browser status line via a JavaScript program. A message displayed in the status line is a string value stored in the status property of the window object. You can change this information in the status line within a JavaScript program by the including the statement:
window.status=“Place your message here”;
So now you have three different ways to communicate with the user. If you put them altogether, you could display a message to the user on the webpage itself, display a message in an alert dialog box, and display a message in the status line. Example:
if (navigator.appName==”Netscape”)
{
document.write(“You are using Netscape Navigator”);
alert(“Netscape Navigator detected”);
window.status=“Netscape Navigator detected”;
}
else
{
document.write(“You are not using Netscape Navigator”);
alert(“Netscape Navigator required”);
window.status=“Netscape Navigator required”;
}
The status line can be used to let the user know what the program is doing. For example, whenever your script is about to initiate a potentially lengthy process, such as downloading a large graphic image, it is a good idea to display an appropriate message in the status line. This would notify the user that the program is still working and has not crashed.
DYNAMICS GRAPHICS USING JAVASCRIPT EVENTS AND FUNCTIONS
JavaScript gives you additional capabilities beyond HTML when working with images to make graphics “come alive”. In order to do this, you need to understand to have an understanding of JavaScript events and functions.
JAVASCRIPT EVENTS
An event is a system-level response to the occurrence of some specific condition. Conditions can be generated by the Web browser itself, but most are caused by the user performing some action, like moving the mouse, clicking a button, or selecting text. Once a particular event is generated, JavaScript gives you the ability to create Web pages that react to the event. The following table lists the types of events you can use in JavaScript:
Event Name / Event TriggeronAbort / The user aborted the loading of a Web page
onBlur / The user deactivated an object (the object lost focus)
onChange / The user changed the object in some way
onClick / The user clicked the mouse on an object
onError / The JavaScript interpreter encountered a script error
onFocus / The user activated an object (the object received focus)
onLoad / The Web browser finished loading a page
onMouseOver / The mouse pointer passed over an object
onMouseOut / The mouse pointer moved off an object
onSelect / The user selected (highlighted) the contents of an object
onSubmit / The user submitted an HTML form
onUnload / The Web browser unloaded a page from memory
JAVASCRIPT FUNCTIONS
A function is a segment of JavaScript code that can be invoked or called just like the document.write() and alert() methods. The difference is that a method has already been defined as part of the JavaScript programming language, whereas a function is written by the programmer and may contain any number of JavaScript statements, including calls to JavaScript methods or other functions.
IMAGE ROLLOVERS
It is possible to make a graphical hyperlink respond to mouse movements in JavaScript. You can change the appearance of an image when the user moves the mouse pointer over it, which is called an image rollover. In order to accomplish this, you must use the JavaScript events called onMouseOver and onMouseOut. The onMouseOver event occurs when the user moves the mouse pointer over a particular object. The onMouseOut event occurs when the user moves the mouse pointer off of the object.
To create the rollover effect, you will need two graphic images, which should be of the same size. In the sample code, you will use a red arrow image and a blue arrow image, which differ only in their color. What the effect does is ‘swap’ out images depending which mouse event is triggered. For this effect, you will need to put the script tags in the header section of your HTML code. This will allow the Web browser to process the JavaScript code before it begins to display the contents of the document on the screen. For the rollover effect, it will allow the browser to load both images into memory before it displays the body of the Web page. If we fail toe do this, the browser would not know what images it is to load when the onMouseOver and onMouseOut events occur, resulting in a JavaScript error message.
JAVASCRIPT VARIABLES
You will also need to declare some variables in JavaScript for this rollover effect to work. A variable is a name that is assigned to a literal value or to an object. Once this assignment is made, the name can be used throughout the HTML document to refer to that particular value or object. To declare a variable in JavaScript, you use the keyword ‘var’, followed by the name of the variable, and then declare the data type for the variable. For the rollover effect, the type of variable we will declare is an image. Example:
var blueArrow = new Image;
The ‘new Image’ portion of the above statement is executing a special method called a constructor. It is ‘constructing’ (creating) a new image object and saving a reference to that object in a variable we are naming ‘blueArrow’.You will also need to declare another variable for the red arrow, so that we can swap out the two images.
Once the variables are declared, we need to assign the values to the variables. This is accomplished with an assignment statement. In this case, we need to use the source property to assign the image to the variable. Example:
blueArrow.src = “bluearrow.gif”;
This statement tells JavaScript that the source (src) property of the blueArrow object will contain the graphic image stored in the file bluearrow.gif (sets the source property of the object to that image). It causes the browser to load the blue arrow image into memory.
USER-DEFINED JAVASCRIPT FUNCTIONS
When JavaScript detects that an event has occurred, it can execute functions to perform various tasks, depending on the JavaScript statements contained in the functions. For the rollover effect, you want to initially display the first image on the screen when the page is loaded and then swap the image for the second image when the mouse pointer rolls over it. To create a function in JavaScript, you use the keyword “function” followed by the name of the function. Then you enclose the block of statements you want the function to execute in curly braces ({}). Example:
function turnBlue()
{
document.arrow.src = blueArrow.src;
return;
}
The statement “document.arrow.src”, refers to the image “placeholder”, where either image will be displayed in your page document (the <img> tag in the document). This statement in the above function assigns the variable “blueArrow.src” to the source property of the image named “arrow”. The image tag includes the name attribute to allow you to assign a variable name to the image object. Since the arrow image is part of the HTML document, it can be referenced in JavaScript code as “document.arrow”. The image tag in HTML would look like this:
<img name=”arrow” src=”bluearrow.gif”>
The source in this image tag would allow the initial graphic displayed on the page when the page is loaded to be the blue arrow.
The return statement tells JavaScript to return to the next statement in the code after the statement that caused this function to be executed. To complete the rollover effect, you will need a second user-defined function to assign the red arrow image to the arrow source property.
EVENT HANDLING LOGIC
Once the variables are declared and the functions are coded, you will need to call the functions based on the triggering of the appropriate event. The way in which JavaScript code can interact with standard HTML tags is through event handling logic. JavaScript event handling statements are actually placed within a standard HTML tag. The statements that handle the onMouseOver and onMouseOut events are located within the opening anchor (<a>) tag. These statements will be needed to execute the image swap for the rollover effect. The statements look like this: