JavaScript in one page | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Contents: Review: Review, Allocation, Simple Examples; JavaScript Language: Values, Data type conversion, Variables, Literals, Expressions, Operators, Statements, Functions, Built-in Functions, Objects, Built-in Objects, Event; Built-in JavaScript Objects: Root (Root Properties, Root Methods), Array (Array Description, Array Properties, Array Methods), Boolean (Boolean Description), Data (Data Description, Data Methods), Function (Function Description), Image (Image Description, Image Properties), Math (Math Description, Math Properties, Math Methods), Number (Number Description, Number Properties), String (String Description, String Properties, String Methods); |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Review | Allocation | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript is a compact, object-based scripting language for developing client and server Internet applications.
Netscape Navigator interprets JavaScript statements embedded in an HTML page, and LiveWire enables you to create server-based applications similar
to Common Gateway Interface (CGI) programs. JavaScript is Netscape's cross-platform, object-based scripting language for client and server applications. There are two types of JavaScript:
|
<html lang="en"> <head> <title>... replace with your document's title ...</title> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <script type="text/javascript" src="... insert link to file with your JavaScript code here ..."></script> <script type="text/javascript"> //<!-- Begin to hide script contents from old browsers. ... or insert your JavaScript code here ... // End the hiding here. --> </script> </head> <body> ... replace with your document's content ... <script type="text/javascript"> //<!-- Begin to hide script contents from old browsers. ... or insert your JavaScript code here ... // End the hiding here. --> </script> ... replace with your document's content ... <input type="button" value="Click Me" onClick="... or insert your JavaScript code here ..." /> <a href="... any link or sharp ..." onBlur="... or insert your JavaScript code here ...">... replace with your text ...</a> ... replace with your document's content ... </body> </html> |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Simple Examples | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Hello World! | Defining and Dalling Functions | Using an Event Handler | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Code: <html> <head></head> <body> <strong>Example:</strong> <script type="text/javascript"> //<!-- document.write("Hello World!"); //--> </script> <div>All done.</div> </body> </html> |
Example: All done.
|
Code: <html> <head> <script type="text/javascript"> //<!-- function square(number) { return number * number; } //--> </script> </head> <body> <strong>Example:</strong> <script type="text/javascript"> //<!-- document.write("The function"); document.write(" returned "); document.write(square(5), "."); //--> </script> <div>All done.</div> </body> </html> |
Example: All done.
|
Code: <html> <head> <script type="text/javascript"> //<!-- function compute(f) { if (confirm("Are you sure?")) f.result.value = eval(f.expr.value) else alert("Please come back again.") } //--> </script> </head> <body> <strong>Example:</strong> <form> Enter an expression: <input type="text" name="expr" size="10" value="2+2" /><br/> <input type="button" value="Calculate" onClick="compute(this.form)" /><br/> Result: <input type="text" name="result" size="10" /><br/> </form> </body> </html> |
Example: |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Values | Data type conversion | Variables | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript recognizes the following types of values:
|
JavaScript is a loosely typed language. That means you do not have to specify the data type of a variable when you declare it,
and data types are converted automatically as needed during script execution. So, for example, you could define a variable as follows:
var answer = 42
And later, you could assign the same variable a string value, for example,
answer = "Thanks for all the fish..."
Because JavaScript is loosely typed, this assignment does not cause an error message.
In expressions involving numeric and string values, JavaScript converts the numeric values to strings.
For example, consider the following statements:
x = "The answer is " + 42
y = 42 + " is the answer." The first statement returns the string "The answer is 42." The second statement returns the string "42 is the answer."
|
You use variables as symbolic names for values in your application. You give variables names by which you refer to
them and which must conform to certain rules.
A JavaScript identifier, or name, must start with a letter or underscore ("_"); subsequent characters can also be digits (0-9).
Because JavaScript is case sensitive, letters include the characters "A" through "Z" (uppercase) and the characters "a" through "z" (lowercase).
Some examples of legal names are Number_hits, temp99, and _name.
You can declare a variable in two ways:
When you set a variable identifier by assignment outside of a function, it is called a global variable,
because it is available everywhere in the current document. When you declare a variable within a function,
it is called a local variable, because it is available only within the function. Using var is optional,
but you need to use it if you want to declare a local variable inside a function that has already
been declared as a global variable.
You can access global variables declared in one window or frame from another window or frame by specifying the window or frame name.
For example, if a variable called phoneNumber is declared in a FRAMESET document, you can refer to this variable from a child frame as parent.phoneNumber.
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Literals | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
You use literals to represent values in JavaScript. These are fixed values, not variables, that you literally provide in your script.
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Integers | Floating-point literals | Boolean literals | String literals | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Integers can be expressed in decimal (base 10), hexadecimal (base 16), and octal (base 8). A decimal integer literal consists of
a sequence of digits without a leading 0 (zero). A leading 0 (zero) on an integer literal indicates it is in octal;
a leading 0x (or 0X) indicates hexadecimal. Hexadecimal integers can include digits (0-9) and the letters a-f and A-F.
Octal integers can include only the digits 0-7. Some examples of integer literals are: 42, 0xFFF, and -345.
|
A floating-point literal can have the following parts: a decimal integer, a decimal point ("."), a fraction (another decimal number),
an exponent, and a type suffix. The exponent part is an "e" or "E" followed by an integer, which can be signed (preceded by "+" or "-").
A floating-point literal must have at least one digit, plus either a decimal point or "e" (or "E").
Some examples of floating-point literals are 3.1415, -3.1E12, .1e12, and 2E-12
|
The Boolean type has two literal values: true and false.
|
A string literal is zero or more characters enclosed in double (") or single (') quotation marks.
A string must be delimited by quotation marks of the same type; that is, either both single quotation marks or double quotation marks.
The following are examples of string literals: "blah", 'blah', "1234", "one line \n another line".
In addition to ordinary characters, you can also include special characters in strings, as shown in the last element in the preceding list.
For characters not listed in the preceding table, a preceding backslash is ignored, with the exception of a quotation mark and the backslash character itself.
You can insert quotation marks inside strings by preceding them with a backslash. This is known as escaping the quotation marks. For example,
var quote = "He read \"The Cremation of Sam McGee\" by R.W. Service."
document.write(quote) The result of this would be
He read "The Cremation of Sam McGee" by R.W. Service.
To include a literal backslash inside a string, you must escape the backslash character. For example, to assign the file path c:\temp to a string,
use the following:
var home = "c:\\temp"
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Expressions | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
An expression is any valid set of literals, variables, operators, and expressions that evaluates to a single value; the value can be a number,
a string, or a logical value.
Conceptually, there are two types of expressions: those that assign a value to a variable, and those that simply have a value.
For example, the expression
x = 7 is an expression that assigns x the value seven.
This expression itself evaluates to seven. Such expressions use assignment operators. On the other hand,
the expression 3 + 4 simply evaluates to seven; it does not perform an assignment.
The operators used in such expressions are referred to simply as operators.
JavaScript has the following types of expressions:
The special keyword null denotes a null value. In contrast, variables that have not been assigned a value are undefined and
will cause a runtime error if used as numbers or as numeric variables.
Array elements that have not been assigned a value, however,
evaluate to false. For example, the following code executes the function myFunction because the array element is not defined:
myArray=new Array()
if (!myArray["notThere"]) myFunction() A conditional expression can have one of two values based on a condition. The syntax is
(condition) ? val1 : val2
If condition is true, the expression has the value of val1. Otherwise it has the value of val2. You can use a conditional expression anywhere you would use a
standard expression.
For example,
status = (age >= 18) ? "adult" : "minor"
This statement assigns the value "adult" to the variable status if age is eighteen or greater. Otherwise, it assigns the value "minor" to status.
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Operators | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript has assignment, comparison, arithmetic, bitwise, logical, string, and special operators. This section describes the operators and contains
information about operator precedence.
There are both binary and unary operators. A binary operator requires two operands, one before the operator and one after the operator:
operand1 operator operand2
For example, 3+4 or x*y.
A unary operator requires a single operand, either before or after the operator:
operator operand
or
operand operator
For example, x++ or ++x.
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Assignment operators | Comparison operators | Logical operators | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
An assignment operator assigns a value to its left operand based on the value of its right operand.
The basic assignment operator is equal (=), which assigns the value of its right operand to its left operand. That is, x = y assigns the value of y to x.
The other operators are shorthand for standard operations, as shown in the following table:
|
A comparison operator compares its operands and returns a logical value based on whether the comparison is true or not.
The operands can be numerical or string values. When used on string values, the comparisons are based on the standard lexicographical ordering.
They are described in the following table.
|
Logical operators take Boolean (logical) values as operands and return a Boolean value. They are described in the following table.
Notes
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Arithmetic operators | Bitwise operators | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Arithmetic operators take numerical values (either literals or variables) as their operands and return a single numerical value.
The standard arithmetic operators are addition (+), subtraction (-), multiplication (*), and division (/).
These operators work as they do in other programming languages.
|
Bitwise operators treat their operands as a set of bits (zeros and ones), rather than as decimal, hexadecimal, or octal numbers.
For example, the decimal number nine has a binary representation of 1001. Bitwise operators perform their operations on such binary representations,
but they return standard JavaScript numerical values.
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
String operators | Special operators | Operator precedence | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
In addition to the comparison operators, which can be used on string values, the concatenation operator (+) concatenates two string values together,
returning another string that is the union of the two operand strings. For example, "my " + "string" returns the string "my string".
The shorthand assignment operator += can also be used to concatenate strings. For example, if the variable mystring has the value "alpha,"
then the expression mystring += "bet" evaluates to "alphabet" and assigns this value to mystring.
|
|
The precedence of operators determines the order they are applied when evaluating an expression. You can override operator precedence by using parentheses.
The following table describes the precedence of operators, from lowest to highest:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Statements (in alphabetical order) | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
break |
break
A statement that terminates the current while or for loop and transfers program control to the statement following the terminated loop.
|
/* The following function has a break statement that terminates the while loop when i is 3, and then returns the value 3 * x. */
function testBreak(x) {
var i = 0; while (i < 6) { if (i == 3) break; i++; } return i*x; } |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
comment
Notations by the author to explain what a script does. Comments are ignored by the interpreter. JavaScript supports Java-style comments:
|
// This is a single-line comment. /* This is a multiple-line comment. It can be of any length, and you can put whatever you want here. */ |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
continue |
continue
A statement that terminates execution of the block of statements in a while or for loop,
and continues execution of the loop with the next iteration. In contrast to the break statement,
continue does not terminate the execution of the loop entirely: instead,
|
/* The following example shows a while loop that has a continue statement that executes when the value of i is 3. Thus, n takes on the values 1, 3, 7, and 12. */
i = 0;
n = 0; while (i < 5) { i++; if (i == 3) continue; n += i; } |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
for ([initial-expression;] [condition;] [increment-expression]) { statements } |
for
A statement that creates a loop that consists of three optional expressions,
enclosed in parentheses and separated by semicolons, followed by a block of statements executed in the loop.
Arguments
|
/* The following for statement starts by declaring the variable i and initializing it to zero.
It checks that i is less than nine, performs the two succeeding statements, and increments i by one after each pass through the loop. */
for (var i = 0; i < 9; i++) {
n += i; myfunc(n); } |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
for (variable in object) { statements } |
for...in
A statement that iterates a specified variable over all the properties of an object.
For each distinct property, JavaScript executes the specified statements.
Arguments
|
/* The following function takes as its argument an object and the object's name.
It then iterates over all the object's properties and returns a string that lists the property names and their values. */
function dump_props(obj, obj_name) {
var result = ""; for (var i in obj) { result += obj_name + "." + i + " = " + obj[i] + "<br />"; } result += "<hr>"; return result; } |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
function name([param] [, param] [..., param]) { statements } |
function
A statement that declares a JavaScript function name with the specified parameters param. Acceptable parameters include strings, numbers,
and objects.
To return a value, the function must have a return statement that specifies the value to return.
You cannot nest a function statement in another statement or in itself.
All parameters are passed to functions, by value. In other words, the value is passed to the function, but if the function changes the value of
the parameter, this change is not reflected globally or in the calling function.
Arguments
|
/* This function returns the total dollar amount of sales, when given the number of units sold of products a, b, and c. */
function calc_sales(units_a, units_b, units_c) {
return units_a*79 + units_b*129 + units_c*699; } |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
if (condition) { statements1 } [else { statements2 }] |
if...else
A statement that executes a set of statements if a specified condition is true. If the condition is false,
another set of statements can be executed.
Arguments
|
if ( cipher_char == from_char ) { result = result + to_char; x++; } else result = result + clear_char |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
objectName = new objectType ( param1 [,param2] ...[,paramN] ) |
new
An operator that lets you create an instance of a user-defined object type or of one of the built-in object
types Array, Boolean, Date, Function, Math, Number, or String.
Creating a user-defined object type requires two steps:
To define an object type, create a function for the object type that specifies its name, properties, and methods.
An object can have a property that is itself another object. See the examples below.
You can always add a property to a previously defined object.
For example, the statement car1.color = "black" adds a property color to car1, and assigns it a value of "black".
However, this does not affect any other objects. To add the new property to all objects of the same type,
you must add the property to the definition of the car object type.
Arguments
|
/* Example 1: object type and object instance.
Suppose you want to create an object type for cars. You want this type of object to be called car,
and you want it to have properties for make, model, and year. To do this, you would write the following function: */
function car(make, model, year) {
this.make = make; this.model = model; this.year = year; } mycar = new car("Eagle", "Talon TSi", 1993); /* Example 2: object property that is itself another object. Suppose you define an object called person as follows: */
function person(name, age, sex) {
this.name = name this.age = age this.sex = sex } /* And then instantiate two new person objects as follows: */
rand = new person("Rand McNally", 33, "M")ken = new person("Ken Jones", 39, "M") /* Then you can rewrite the definition of car to include an owner property that takes a person object, as follows: */
function car(make, model, year, owner) {this.make = make; this.model = model; this.year = year; this.owner = owner; } /* To instantiate the new objects, you then use the following: */
car1 = new car("Eagle", "Talon TSi", 1993, rand);car2 = new car("Nissan", "300ZX", 1992, ken) /* Instead of passing a literal string or integer value when creating the new objects,
the above statements pass the objects rand and ken as the parameters for the owners. To find out the name of the owner of car2,
you can access the following property: */
car2.owner.name
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
return expression |
return
A statement that specifies the value to be returned by a function.
|
/* The following function returns the square of its argument, x, where x is a number. */
function square( x ) {
return x * x } |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
switch(variable) { case value_1: statements_1; break; case value_1: statements_2; break; ... default: statements_default; } |
switch
The switch statement can be used for multiple branches based on a number or string.
Arguments:
|
switch(a) {
case 1: doit(); break; case 2: doit2(); break; default: donothing(); } |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
this[.propertyName] |
this
A keyword that you can use to refer to the current object. In general, in a method this refers to the calling object.
|
/* Suppose a function called validate validates an object's value property, given the object and the high and low values: */
function validate(obj, lowval, hival) {
if ((obj.value < lowval) || (obj.value > hival)) alert("Invalid Value!") } /* You could call validate in each form element's onChange event handler, using this to pass it the form element, as in the following example: */
<b>Enter a number between 18 and 99:</b>
<input type="text" name="age" size="3" onChange="validate(this, 18, 99)" /> |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
var varname [= value] [..., varname [= value] ] |
var
A statement that declares a variable, optionally initializing it to a value. The scope of a variable is the current function or,
for variables declared outside a function, the current application.
Using var outside a function is optional; you can declare a variable by simply assigning it a value.
However, it is good style to use var, and it is necessary in functions if a global variable of the same name exists.
Arguments
|
var num_hits = 0, cust_no = 0 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
while (condition) { statements } do { statements } while (condition) |
while
A statement that creates a loop that evaluates an expression, and if it is true, executes a block of statements.
The loop then repeats, as long as the specified condition is true.
Arguments
|
/* The following while loop iterates as long as n is less than three. */
n = 0;
x = 0; while( n < 3 ) { n ++; x += n; }
/* Each iteration, the loop increments n and adds it to x. Therefore, x and n take on the following values:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
with (object) { statements } |
with
A statement that establishes the default object for a set of statements. Within the set of statements,
any property references that do not specify an object are assumed to be for the default object.
Arguments
|
The following with statement specifies that the Math object is the default object. The statements following
the with statement refer to the PI property and the cos and sin methods, without specifying an object. JavaScript assumes the Math object for these references.
var a, x, y;
var r=10; with (Math) { a = PI * r * r; x = r * cos(PI); y = r * sin(PI/2); } |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Functions | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Functions are one of the fundamental building blocks in JavaScript.
A function is a JavaScript procedure - a set of statements that performs a specific task.
To use a function, you must first define it; then your script can call it.
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Defining functions | Using functions | Using the arguments array | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
A function definition consists of the function keyword, followed by
In Navigator JavaScript, it is good practice to define all your functions in the HEAD of a page so that when a user loads the page,
the functions are loaded first.
For example, here is the definition of a simple function named pretty_print:
function pretty_print(str) {
document.write("<hr><p>" + str) } , or semantically equivalent:
var pretty_print = function(str) {
document.write("<hr><p>" + str) } This function takes a string, str, as its argument, adds some HTML tags to it using the concatenation operator (+),
and then displays the result to the current document using the write method.
|
In a Navigator application, you can use (or call) any function defined in the current page.
You can also use functions defined by other named windows or frames. In a LiveWire application, you can use any function compiled with the application.
Defining a function does not execute it. You have to call the function for it to do its work.
For example, if you defined the example function pretty_print in the HEAD of the document, you could call it as follows:
<script type="text/javascript">
pretty_print("This is some text to display") </script> The arguments of a function are not limited to strings and numbers. You can pass whole objects to a function, too.
A function can even be recursive, that is, it can call itself. For example, here is a function that computes factorials:
function factorial(n) {
if ((n == 0) || (n == 1)) return 1 else { result = (n * factorial(n-1) ) return result } } You could then display the factorials of one through five as follows:
for (x = 0; x < 5; x++) {
document.write("<br />", x, " factorial is ", factorial(x)) } The results are:
0 factorial is 1
1 factorial is 1 2 factorial is 2 3 factorial is 6 4 factorial is 24 5 factorial is 120 |
The arguments of a function are maintained in an array. Within a function, you can address the parameters passed to it as follows:
functionName.arguments[i]
where functionName is the name of the function and i is the ordinal number of the argument, starting at zero.
So, the first argument passed to a function named myfunc would be myfunc.arguments[0].
The total number of arguments is indicated by the variable arguments.length.
Using the arguments array, you can call a function with more arguments than it is formally declared to accept using.
This is often useful if you don't know in advance how many arguments will be passed to the function.
You can use arguments.length to determine the number of arguments actually passed to the function, and then treat each argument using the arguments array.
For example, consider a function defined to create HTML lists. The only formal argument for the function is a string that is "U" for an unordered
(bulleted) list or "O" for an ordered (numbered) list. The function is defined as follows:
function list(type) {
document.write("<" + type + "l>") // begin list // iterate through arguments for (var i = 1; i < list.arguments.length; i++) document.write("<li>" + list.arguments[i]); document.write("</" + type + "l>") // end list } You can pass any number of arguments to this function, and it will then display each argument as an item in the indicated type of list.
For example, the following call to the function
list("o", "one", 1967, "three", "etc., etc...")
results in this output:
1.one
2.1967 3.three 4.etc., etc... |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Built-in Functions | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
isNaN(testValue) |
isNaN function
The isNaN function evaluates an argument to determine if it is "NaN" (not a number).
Arguments
On platforms that support NaN, the parseFloat and parseInt functions return "NaN" when they evaluate a value that is not a number.
isNaN returns true if passed "NaN," and false otherwise.
|
/* The following code evaluates floatValue to determine if it is a number and then calls a procedure accordingly: */
floatValue=parseFloat(toFloat);
if (isNaN(floatValue)) { notFloat(); } else { isFloat(); } |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
parseFloat(str) |
parseFloat
parseFloat parses its argument, the string str, and attempts to return a floating-point number.
If it encounters a character other than a sign (+ or -), a numeral (0-9), a decimal point, or an exponent,
then it returns the value up to that point and ignores that character and all succeeding characters.
If the first character cannot be converted to a number, it returns "NaN" (not a number).
|
parseFloat("5.347") | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
parseInt(str [, radix]) |
parseInt
parseInt parses its first argument, the string str, and attempts to return an integer of the specified radix (base),
indicated by the second, optional argument, radix. For example, a radix of ten indicates to convert to a decimal number,
eight octal, sixteen hexadecimal, and so on. For radixes above ten, the letters of the alphabet indicate numerals greater than nine.
For example, for hexadecimal numbers (base 16), A through F are used.
If parseInt encounters a character that is not a numeral in the specified radix, it ignores
it and all succeeding characters and returns the integer value parsed up to that point.
If the first character cannot be converted to a number in the specified radix, it returns "NaN."
The parseInt function truncates numbers to integer values.
|
parseInt("7") |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Objects | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript is based on a simple object-oriented paradigm.
An object is a construct with properties that are JavaScript variables or other objects.
An object also has functions associated with it that are known as the object's methods.
In addition to objects that are built into the Navigator client and the LiveWire server, you can define your own objects.
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Creating new objects | Defining methods | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Both client and server JavaScript have a number of predefined objects. In addition, you can create your own objects.
Creating your own object requires two steps:
To define an object type, create a function for the object type that specifies its name, properties, and methods.
For example, suppose you want to create an object type for cars. You want this type of object to be called car, and you want it to have properties
for make, model, year, and color. To do this, you would write the following function:
function car(make, model, year) {
this.make = make; this.model = model; this.year = year; } Notice the use of this to assign values to the object's properties based on the values passed to the function.
Now you can create an object called mycar as follows:
mycar = new car("Eagle", "Talon TSi", 1993)
This statement creates mycar and assigns it the specified values for its properties. Then the value of mycar.make is the string "Eagle,"
mycar.year is the integer 1993, and so on.
You can create any number of car objects by calls to new. For example,
kenscar = new car("Nissan", "300ZX", 1992)
An object can have a property that is itself another object. For example, suppose you define an object called person as follows:
function person(name, age, sex) {
this.name = name; this.age = age; this.sex = sex; } and then instantiate two new person objects as follows:
rand = new person("Rand McKinnon", 33, "M")
ken = new person("Ken Jones", 39, "M") Then you can rewrite the definition of car to include an owner property that takes a person object, as follows:
function car(make, model, year, owner) {
this.make = make; this.model = model; this.year = year; this.owner = owner; } To instantiate the new objects, you then use the following:
car1 = new car("Eagle", "Talon TSi", 1993, rand)
car2 = new car("Nissan", "300ZX", 1992, ken) Notice that instead of passing a literal string or integer value when creating the new objects,
the above statements pass the objects rand and ken as the arguments for the owners.
Then if you want to find out the name of the owner of car2, you can access the following property:
car2.owner.name
Note that you can always add a property to a previously defined object. For example, the statement
car1.color = "black"
adds a property color to car1, and assigns it a value of "black." However, this does not affect any other objects.
To add the new property to all objects of the same type, you have to add the property to the definition of the car object type.
|
A method is a function associated with an object. You define a method the same way you define a standard function.
Then you use the following syntax to associate the function with an existing object:
object.methodname = function_name
where object is an existing object, methodname is the name you are assigning to the method, and function_name is the name of the function.
You can then call the method in the context of the object as follows:
object.methodname(params);
You can define methods for an object type by including a method definition in the object constructor function.
For example, you could define a function that would format and display the properties of the previously-defined car objects; for example,
function displayCar() {
var result = "A Beautiful " + this.year + " " + this.make + " " + this.model; pretty_print(result); } where pretty_print is the function (defined in "Functions") to display a horizontal rule and a string.
Notice the use of this to refer to the object to which the method belongs.
You can make this function a method of car by adding the statement
this.displayCar = displayCar;
to the object definition. So, the full definition of car would now look like
function car(make, model, year, owner) {
this.make = make;
this.model = model; this.year = year; this.owner = owner; this.displayCar = displayCar; } Then you can call the displayCar method for each of the objects as follows:
car1.displayCar()
car2.displayCar() This will produce output like:
A Beautiful 1993 Eagle Talon TSi
A Beautiful 1992 Nissan 300ZX |
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Defining object with "return" | Defining object with "this" | Defining object with "prototype" | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Let's consider a person object with first and last name fields. There are two ways in which their name might be displayed: as "first last" or as "last, first". | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
function Person(first, last) {
return { first: first, last: last, fullName: function() { return this.first + ' ' + this.last; }, fullNameReversed: function() { return this.last + ', ' + this.first; } } } use (with trace):
> s = Person("Simon", "Willison")
> s.fullName() Simon Willison > s.fullNameReversed() Willison, Simon |
function Person(first, last) {
this.first = first; this.last = last; this.fullName = function() { return this.first + ' ' + this.last; } this.fullNameReversed = function() { return this.last + ', ' + this.first; } } , or:
function personFullName() {
return this.first + ' ' + this.last; } function personFullNameReversed() { return this.last + ', ' + this.first; } function Person(first, last) { this.first = first; this.last = last; this.fullName = personFullName this.fullNameReversed = personFullNameReversed } use (with trace):
> s = new Person("Simon", "Willison")
> s.fullName() Simon Willison > s.fullNameReversed() Willison, Simon |
function Person(first, last) {
this.first = first; this.last = last; } Person.prototype.fullName = function() { return this.first + ' ' + this.last; } Person.prototype.fullNameReversed = function() { return this.last + ', ' + this.first; } use (with trace):
> s = new Person("Simon", "Willison")
> s.fullName() Simon Willison > s.fullNameReversed() Willison, Simon This is an incredibly powerful tool. JavaScript lets you modify something's prototype at any time in your program, which means you can add extra methods to existing objects at runtime:
> s = new Person("Simon", "Willison");
> s.firstNameCaps(); TypeError on line 1: s.firstNameCaps is not a function > Person.prototype.firstNameCaps = function() { > return this.first.toUpperCase() > } > s.firstNameCaps() SIMON |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Built-in Objects | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Root Object Properties (for all built-in objects) | JavaScript Root Object Methods (for all built-in objects) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
constructor | A reference to the function that created the object |
eval(string) |
Evaluates a string of JavaScript code in the context of the specified object.
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Example №1
In this example we will show how to use the constructor property:
var test=new Array();
if (test.constructor==Array) {document.write("This is an Array")}; if (test.constructor==Boolean) {document.write("This is a Boolean")}; if (test.constructor==Date) {document.write("This is a Date")}; if (test.constructor==String) {document.write("This is a String")} The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Example 2
In this example we will show how to use the constructor property:
function employee(name,jobtitle,born) {this.name=name; this.jobtitle=jobtitle; this.born=born;}
var fred=new employee("Fred Flintstone","Caveman",1970); document.write(fred.constructor); The output of the code above will be:
|
toSource() |
Represents the source code of an object
Note:
|
Example
In this example we will show how to use the toSource() method:
function employee(name,jobtitle,born) {
this.name=name; this.jobtitle=jobtitle; this.born=born; } var fred=new employee("Fred Flintstone","Caveman",1970); document.write(fred.toSource()); The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
prototype | Lets you add a properties to an object. |
toString() |
Converts a Boolean value to a string and returns the result
Note:
|
Example
In this example we will create an array and convert it to a string:
var arr = new Array(3);
arr[0] = "Jani"; arr[1] = "Hege"; arr[2] = "Stale"; document.write(arr.toString()); The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Example
In this example we will show how to use the prototype property to add a property to an object:
function employee(name,jobtitle,born) {this.name=name; this.jobtitle=jobtitle; this.born=born;}
var fred=new employee("Fred Flintstone","Caveman",1970); employee.prototype.salary=null; fred.salary=20000; document.write(fred.salary); The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
valueOf() |
Returns the primitive value of a object
The primitive value is inherited by all objects descended from the object.
The valueOf() method is usually called automatically by JavaScript behind the scenes and not explicitly in code.
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Array Object Description | JavaScript Array Object Properties | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Review
JavaScript does not have an explicit array data type. However, you can use the built-in Array object and its methods to work with arrays in
your applications. The Array object has methods for joining, reversing, and sorting arrays. It has a property for determining the array length.
An array is an ordered set of values that you reference through a name and an index. For example, you could have an array called emp
that contains employees' names indexed by their employee number. So emp[1] would be employee number one, emp[2] employee number two, and so on.
To create an Array object:
Arguments
The Array object has the following main methods:
For example, suppose you define the following array:
myArray = new Array("Wind","Rain","Fire")
myArray.join() returns "Wind,Rain,Fire"; myArray.reverse transposes the array so that myArray[0] is "Fire", myArray[1] is "Rain",
and myArray[2] is "Wind". myArray.sort sorts the array so that myArray[0] is "Fire", myArray[1] is "Rain", and myArray[2] is "Wind". myArray.
Defining Arrays
The Array object is used to store a set of values in a single variable name.
We define an Array object with the new keyword. The following code line defines an Array object called myArray:
var myArray=new Array()
There are two ways of adding values to an array (you can add as many values as you need to define as many variables you require).
1:
var mycars=new Array();
mycars[0]="Saab"; mycars[1]="Volvo"; mycars[2]="BMW" You could also pass an integer argument to control the array's size:
var mycars=new Array(3);
mycars[0]="Saab"; mycars[1]="Volvo"; mycars[2]="BMW" 2:
var mycars=new Array("Saab","Volvo","BMW")
Note:
If you specify numbers or true/false values inside the array then the type of variables will be numeric or Boolean instead of string.
Accessing Arrays
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])
will result in the following output:
Saab
Modify Values in Existing Arrays
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
Two-dimensional array
The following code creates a two-dimensional array and displays the results.
a = new Array(4);
for (i=0; i < 4; i++) { a[i] = new Array(4); for (j=0; j < 4; j++) { a[i][j] = "["+i+","+j+"]"; } } for (i=0; i < 4; i++) { str = "Row "+i+":"; for (j=0; j < 4; j++) { str += a[i][j]; } document.write(str,"<p>") } This example displays the following results:
Multidimensional array test
Row 0:[0,0][0,1][0,2][0,3] Row 1:[1,0][1,1][1,2][1,3] Row 2:[2,0][2,1][2,2][2,3] Row 3:[3,0][3,1][3,2][3,3] |
length | Reflects the number of elements in an array | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Array Object Methods | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
concat (arrayX,arrayX,......,arrayX) |
Joins two or more arrays and returns the result
This method does not change the existing arrays, it only returns a copy of the joined arrays.
Arguments
|
Example №1:
Here we create two arrays and show them as one using concat():
var arr = new Array(3)
arr[0] = "Jani"; arr[1] = "Tove"; arr[2] = "Hege"; var arr2 = new Array(3) arr2[0] = "John"; arr2[1] = "Andy"; arr2[2] = "Wendy"; document.write(arr.concat(arr2)); The output of the code above will be:
|
Example №2:
Here we create three arrays and show them as one using concat():
var arr = new Array(3)
arr[0]="Jani"; arr[1]="Tove"; arr[2]="Hege"; var arr2 = new Array(3) arr2[0]="John"; arr2[1]="Andy"; arr2[2]="Wendy"; var arr3 = new Array(2) arr3[0]="Stale"; arr3[1]="Borge"; document.write(arr.concat(arr2,arr3)) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
eval(string) |
Evaluates a string of JavaScript code in the context of the specified object.
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
join(separator) |
Joins all elements of an array into a string.
The string conversion of all array elements are joined into one string.
|
Example:
The following example creates an array, a with three elements, then joins the array three times: using the default separator,
then a comma and a space, and then a plus.
a = new Array("Wind","Rain","Fire")
document.write(a.join() +"<br />") document.write(a.join(", ") +"<br />") document.write(a.join(" + ") +"<br />") This code produces the following output:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
pop() |
Removes and returns the last element of an array
The pop() method is used to remove and return the last element of an array.
Note:
This method changes the length of the array.
Tip:
To remove and return the first element of an array, use the shift() method.
|
Example:
In this example we will create an array, and then remove the last element of the array. Note that this will also change the length of the array:
var arr = new Array(3)
arr[0] = "Jani"; arr[1] = "Hege"; arr[2] = "Stale" document.write(arr + "<br />") document.write(arr.pop() + "<br />") document.write(arr) The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
push() |
Adds one or more elements to the end of an array and returns the new length.
The push() method adds one or more elements to the end of an array and returns the new length.
Arguments
Note:
This method changes the length of the array.
Tip:
To add one or more elements to the beginning of an array, use the unshift() method.
|
Example:
In this example we will create an array, and then change the length of it by adding a element:
var arr = new Array(3)
arr[0] = "Jani"; arr[1] = "Hege"; arr[2] = "Stale"; document.write(arr + "<br />"); document.write(arr.push("Kai Jim")+"<br/>"); document.write(arr) The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
reverse() |
Transposes the elements of an array: the first array element becomes the last and the last becomes the first.
The reverse method transposes the elements of the calling array object.
|
Example:
The following example creates an array myArray, containing three elements, then reverses the array.
myArray = new Array("one", "two", "three")
myArray.reverse() This code changes myArray so that:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
shift() |
Removes and returns the first element of an array
The shift() method is used to remove and return the first element of an array.
Note:
This method changes the length of the array.
Tip:
To remove and return the last element of an array, use the pop() method.
|
Example:
In this example we will create an array, and then remove the first element of the array. Note that this will also change the length of the array:
var arr = new Array(3);
arr[0] = "Jani"; arr[1] = "Hege"; arr[2] = "Stale"; document.write(arr + "<br />"); document.write(arr.shift() + "<br />"); document.write(arr); The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
slice(start,end) |
Returns selected elements from an existing array
The slice() method returns selected elements from an existing array.
Arguments:
Note:
If end is not specified, slice() selects all elements from the specified start position and to the end of the array.
Tip:
You can use negative numbers to select from the end of the array.
|
Example №1:
In this example we will create an array, and then display selected elements from it:
var arr = new Array(3);
arr[0] = "Jani"; arr[1] = "Hege"; arr[2] = "Stale"; document.write(arr + "<br />"); document.write(arr.slice(1)+"<br/>"); document.write(arr); The output of the code above will be:
|
Example №2:
In this example we will create an array, and then display selected elements from it:
var arr = new Array(6);
arr[0] = "Jani"; arr[1] = "Hege"; arr[2] = "Stale"; arr[3] = "Kai Jim"; arr[4] = "Borge"; arr[5] = "Tove"; document.write(arr + "<br />"); document.write(arr.slice(2,4)+"<br/>"); document.write(arr); The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
sort(sortby) |
Sorts the elements of an array
The sort() method is used to sort the elements of an array.
Argument
Note:
|
Example №1:
In this example we will create an array and sort it alphabetically:
var arr = new Array(6);
arr[0] = "Jani"; arr[1] = "Hege"; arr[2] = "Stale"; arr[3] = "Kai Jim"; arr[4] = "Borge"; arr[5] = "Tove"; document.write(arr + "<br />"); document.write(arr.sort()); The output of the code above will be:
|
Example №2:
In this example we will create an array containing numbers and sort it:
var arr = new Array(6);
arr[0] = "10"; arr[1] = "5"; arr[2] = "40"; arr[3] = "25"; arr[4] = "1000"; arr[5] = "1"; document.write(arr + "<br />"); document.write(arr.sort()); The output of the code above will be:
Note
that the numbers above are NOT sorted correctly (by numeric value). To solve this problem, we must add a function that handles this problem:
Example №3:
function sortNumber(a,b) {return a-b}
var arr = new Array(6); arr[0] = "10"; arr[1] = "5"; arr[2] = "40"; arr[3] = "25"; arr[4] = "1000"; arr[5] = "1"; document.write(arr + "<br />"); document.write(arr.sort(sortNumber)); The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
splice (index,howmany,element1, .....,elementX) |
Removes and adds new elements to an array
The splice() method is used to remove and add new elements to an array.
Arguments:
|
Example №1:
In this example we will create an array and add an element to it:
var arr = new Array(5);
arr[0] = "Jani"; arr[1] = "Hege"; arr[2] = "Stale"; arr[3] = "Kai Jim"; arr[4] = "Borge"; document.write(arr + "<br />"); arr.splice(2,0,"Lene"); document.write(arr + "<br />"); The output of the code above will be:
Example №2:
In this example we will remove the element at index 2 ("Stale"), and add a new element ("Tove") there instead:
var arr = new Array(5);
arr[0] = "Jani"; arr[1] = "Hege"; arr[2] = "Stale"; arr[3] = "Kai Jim"; arr[4] = "Borge"; document.write(arr + "<br />"); arr.splice(2,1,"Tove"); document.write(arr); The output of the code above will be:
|
Example №3:
In this example we will remove three elements starting at index 2 ("Stale"), and add a new element ("Tove") there instead:
var arr = new Array(5);
arr[0] = "Jani"; arr[1] = "Hege"; arr[2] = "Stale"; arr[3] = "Kai Jim"; arr[4] = "Borge"; document.write(arr + "<br />"); arr.splice(2,3,"Tove"); document.write(arr); The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
unshift (newelement1,newelement2, ....,newelementX) |
Adds one or more elements to the beginning of an array and returns the new length.
The unshift() method adds one or more elements to the beginning of an array and returns the new length.
Arguments:
Note:
Tip:
|
Example
In this example we will create an array, add an element to the beginning of the array and then return the new length:
var arr = new Array();
arr[0] = "Jani"; arr[1] = "Hege"; arr[2] = "Stale"; document.write(arr + "<br />"); document.write(arr.unshift("Kai Jim")+"<br/>"); document.write(arr); The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Boolean Object Description | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Review
Use the built-in Boolean object when you need to convert a non-boolean value to a boolean value.
You can use the Boolean object any place JavaScript expects a primitive boolean value.
JavaScript returns the primitive value of the Boolean object by automatically invoking the valueOf method.
To create a Boolean object:
var booleanObjectName = new Boolean(value)
The following examples create Boolean objects:
bfalse = new Boolean(false)
btrue = new Boolean(true) All the following lines of code create Boolean objects with an initial value of false:
var myBoolean=new Boolean(); var myBoolean=new Boolean(0); var myBoolean=new Boolean(null)
var myBoolean=new Boolean(""); var myBoolean=new Boolean(false); var myBoolean=new Boolean(NaN) And all the following lines of code create Boolean objects with an initial value of true:
var myBoolean=new Boolean(true); var myBoolean=new Boolean("true")
var myBoolean=new Boolean("false"); var myBoolean=new Boolean("Richard") |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Data Object Description | JavaScript Data Object Methods | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
Review
JavaScript does not have a date data type. However, you can use the Date object and its methods to
work with dates and times in your applications. The Date object has a large number of methods for setting, getting, and manipulating dates.
It does not have any properties.
JavaScript handles dates similarly to Java. The two languages have many of the same date methods, and both languages store
dates as the number of milliseconds since January 1, 1970, 00:00:00.
Note
Currently, you cannot work with dates prior to January 1, 1970.
To create a Date object:
dateObjectName = new Date([parameters])
where dateObjectName is the name of the Date object being created; it can be a new object or a property of an existing object.
The parameters in the preceding syntax can be any of the following:
Methods of the Date object
The Date object methods for handling dates and times fall into these broad categories:
With the "get" and "set" methods you can get and set seconds, minutes, hours, day of the month, day of the week, months, and years separately.
There is a getDay method that returns the day of the week, but no corresponding setDay method, because the day of the week is set automatically.
These methods use integers to represent these values as follows:
For example, suppose you define the following date:
Xmas95 = new Date("December 25, 1995")
Then Xmas95.getMonth() returns 11, and Xmas95.getYear() returns 95.
The getTime and setTime methods are useful for comparing dates. The getTime method
returns the number of milliseconds since the epoch for a Date object.
For example, the following code displays the number of days left in the current year:
today = new Date()
endYear = new Date("December 31, 1990") // Set day and month endYear.setYear(today.getYear()) // Set year to this year msPerDay = 24 * 60 * 60 * 1000 // Number of milliseconds per day daysLeft = (endYear.getTime() - today.getTime()) / msPerDay daysLeft = Math.round(daysLeft) document.write("Number of days left in the year: " + daysLeft) This example creates a Date object named today that contains today's date.
It then creates a Date object named endYear and sets the year to the current year.
Then, using the number of milliseconds per day, it computes the number of days between today
and endYear, using getTime and rounding to a whole number of days.
The parse method is useful for assigning values from date strings to existing Date objects.
For example, the following code uses parse and setTime to assign a date value to the IPOdate object:
IPOdate = new Date()
IPOdate.setTime(Date.parse("Aug 9, 1995")) Using the Date object: an example
The following example shows a simple application of Date: it displays a continuously-updated digital clock in an HTML text field.
This is possible because you can dynamically change the contents of a text field with JavaScript (in contrast to ordinary text,
which you cannot update without reloading the document).
The display in Navigator looks like this:
The <body>: of the document is:
<body onLoad="JSClock()">
<form name="clockForm"> The current time is <input type="text" name="digits" size="12" value="" /> </form> </body> The <body> tag includes an onLoad event handler. When the page loads, the event handler calls the function JSClock,
defined in the <head>. A form called clockForm includes a single text field named digits, whose value is initially an empty string.
The <head> of the document defines JSClock as follows:
<head>
<script type="text/javascript"> <!-- function JSClock() { var time = new Date() var hour = time.getHours() var minute = time.getMinutes() var second = time.getSeconds() var temp = "" + ((hour > 12) ? hour - 12 : hour) temp += ((minute < 10) ? ":0" : ":") + minute temp += ((second < 10) ? ":0" : ":") + second temp += (hour >= 12) ? " P.M." : " A.M." document.clockForm.digits.value = temp id = setTimeout("JSClock()",1000) } //--> </script> </head> The JSClock function first creates a new Date object called time; since no arguments are given, time is created with the current date and time.
Then calls to the getHours, getMinutes, and getSeconds methods assign the value of the current hour, minute and seconds to hour, minute, and second.
The next four statements build a string value based on the time. The first statement creates a variable temp, assigning it a
value using a conditional expression; if hour is greater than 12, (hour - 13), otherwise simply hour.
The next statement appends a minute value to temp. If the value of minute is less than 10, the conditional expression adds a string
with a preceding zero; otherwise it adds a string with a demarcating colon. Then a statement appends a seconds value to temp in the same way.
Finally, a conditional expression appends "PM" to temp if hour is 12 or greater; otherwise, it appends "AM" to temp.
The next statement assigns the value of temp to the text field:
document.aform.digits.value = temp
This displays the time string in the document.
The final statement in the function is a recursive call to JSClock:
id = setTimeout("JSClock()", 1000)
The built-in JavaScript setTimeout function specifies a time delay to evaluate an expression, in this case a call to JSClock.
The second argument indicates a a delay of 1,000 milliseconds (one second). This updates the display of time in the form at one-second intervals.
Note that the function returns a value (assigned to id), used only as an identifier (which can be used by the clearTimeout method
to cancel the evaluation).
Manipulate 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):
var myDate=new Date()
myDate.setFullYear(2010,0,14) And in the following example we set a Date object to be 5 days into the future:
var myDate=new Date()
myDate.setDate(myDate.getDate()+5) Note:
If adding five days to a date shifts the month or year, the changes are handled automatically by the Date object itself!
Comparing Dates
The Date object is also used to compare two dates.
The following example compares today's date with the 14th January 2010:
var myDate=new Date()
myDate.setFullYear(2010,0,14) var today = new Date() if (myDate>today) alert("Today is before 14th January 2010") else alert("Today is after 14th January 2010") |
Date() |
Returns today's date and time
|
Example
In this example we print the day of the current month:
document.write(Date())
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getDate() |
Returns the day of the month from a Date object (from 1-31)
Note:
|
Example №1
In this example we print the day of the current month:
var d = new Date();
document.write(d.getDate()) The output of the code above will be:
|
Example №2
Here we define a variable with a specific date and then print the day of the month in the variable:
var birthday = new Date("July 21, 1983 01:15:00");
document.write(birthday.getDate()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getDay() |
Returns the day of the week from a Date object (from 0-6)
Note:
|
Example №1
In this example we get the current day (as a number) of the week:
var d = new Date();
document.write(d.getDay()) The output of the code above will be:
|
Example №2
Now we will create an array to get our example to write a weekday, and not just a number:
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"; weekday[6]="Saturday"; document.write("Today it is " + weekday[d.getDay()]); The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getMonth() |
Returns the month from a Date object (from 0-11)
Note:
|
Example №1
In this example we get the current month and print it:
var d = new Date();
document.write(d.getMonth()) The output of the code above will be:
|
Example №2
Now we will create an array to get our example to write the name of the month, and not just a number:
var d=new Date(); var month=new Array(12);
month[0]="January"; month[1]="February"; month[2]="March"; month[3]="April"; month[4]="May"; month[5]="June"; month[6]="July"; month[7]="August"; month[8]="September"; month[9]="October"; month[10]="November"; month[11]="December"; document.write("The month is "+month[d.getMonth()]); The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getFullYear() |
Returns the year, as a four-digit number, from a Date object
Note:
|
Example №1
In this example we get the current year and print it:
var d = new Date();
document.write(d.getFullYear()) The output of the code above will be:
|
Example №2
Here we will extract the year out of the specific date:
var born = new Date("July 21, 1983 01:15:00");
document.write("I was born in " + born.getFullYear()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getHours() |
Returns the hour of a Date object (from 0-23)
Note:
|
Example №1
In this example we get the hour of the current time:
var d = new Date();
document.write(d.getHours()) The output of the code above will be:
|
Example №2
Here we will extract the hour from the specific date and time:
var born = new Date("July 21, 1983 01:15:00");
document.write(born.getHours()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getMinutes() |
Returns the minutes of a Date object (from 0-59)
Note:
|
Example №1
In this example we get the minutes of the current time:
var d = new Date();
document.write(d.getMinutes()) The output of the code above will be:
|
Example №2
Here we will extract the minutes from the specific date and time:
var born = new Date("July 21, 1983 01:15:00");
document.write(born.getMinutes()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getSeconds() |
Returns the seconds of a Date object (from 0-59)
Note:
|
Example №1
In this example we get the seconds of the current time:
var d = new Date();
document.write(d.getSeconds()) The output of the code above will be:
|
Example №2
Here we will extract the seconds from the specific date and time:
var born = new Date("July 21, 1983 01:15:00");
document.write(born.getSeconds()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getMilliseconds() |
Returns the milliseconds of a Date object (from 0-999)
Note:
|
Example №1
In this example we get the milliseconds of the current time:
var d = new Date();
document.write(d.getMilliseconds()) The output of the code above will be:
|
Example №2
Here we will extract the milliseconds from the specific date and time:
var born = new Date("July 21, 1983 01:15:00");
document.write(born.getMilliseconds()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getTime() |
Returns the number of milliseconds since midnight Jan 1, 1970
Note:
|
Example №1
In this example we will get how many milliseconds since 1970/01/01 and print it:
var d = new Date();
document.write(d.getTime() + " milliseconds since 1970/01/01") The output of the code above will be:
|
Example №2
In the following example we will calculate the number of years since 1970/01/01:
var minutes = 1000*60; var hours = minutes*60;
var days = hours*24; var years = days*365; var d = new Date(); var t=d.getTime(); var y=t/years; document.write("It's been: "+y+" years since 1970/01/01!"); The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getTimezoneOffset() |
Returns the difference in minutes between local time and Greenwich Mean Time (GMT)
Note:
|
Example №1
In the following example we get the difference in minutes between local time and Greenwich Mean Time (GMT):
var d = new Date();
document.write(d.getTimezoneOffset()) The output of the code above will be:
|
Example №2
Now we will convert the example above into GMT +/- hours:
var d = new Date();
var gmtHours = d.getTimezoneOffset()/60; document.write("The local time zone is: GMT " + gmtHours); The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getUTCDate() |
Returns the day of the month from a Date object according to universal time (from 1-31)
Note:
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example №1
In this example we print the current day of the month according to UTC:
var d = new Date();
document.write(d.getUTCDate()) The output of the code above will be:
|
Example №2
Here we define a variable with a specific date and then print the day of the month in the variable, according to UTC:
var born = new Date("July 21, 1983 01:15:00");
document.write(born.getUTCDate()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getUTCDay() |
Returns the day of the week from a Date object according to universal time (from 0-6)
Note:
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example №1
In this example we get the current UTC day (as a number) of the week:
var d = new Date();
document.write(d.getUTCDay()) The output of the code above will be:
|
Example №2
Now we will create an array to get our example above to write a weekday, and not just a number:
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"; weekday[6]="Saturday"; document.write("Today it is "+weekday[d.getUTCDay()]) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getUTCMonth() |
Returns the month from a Date object according to universal time (from 0-11)
Note:
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example №1
In this example we get the current month and print it:
var d = new Date();
document.write(d.getUTCMonth()) The output of the code above will be:
|
Example №2
Now we will create an array to get our example to write the name of the month, and not just a number:
var d=new Date(); var month=new Array(12);
month[0]="January"; month[1]="February"; month[2]="March"; month[3]="April"; month[4]="May"; month[5]="June"; month[6]="July"; month[7]="August"; month[8]="September"; month[9]="October"; month[10]="November"; month[11]="December"; document.write("The month is "+month[d.getUTCMonth()]); The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getUTCFullYear() |
Returns the four-digit year from a Date object according to universal time
Note:
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example №1
In this example we get the current year and print it:
var d = new Date();
document.write(d.getUTCHours()) The output of the code above will be:
|
Example №2
Here we will extract the year out of the specific date:
var born = new Date("July 21, 1983 01:15:00");
document.write("I was born in " + born.getUTCFullYear()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getUTCHours() |
Returns the hour of a Date object according to universal time (from 0-23)
Note:
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example №1
In this example we get the UTC hour of the current time:
var d = new Date();
document.write(d.getUTCHours()) The output of the code above will be:
|
Example №2
Here we will extract the UTC hour from the specific date and time:
var born = new Date("July 21, 1983 01:15:00");
document.write(born.getUTCHours()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getUTCMinutes() |
Returns the minutes of a Date object according to universal time (from 0-59)
Note:
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example №1
In this example we get the UTC minutes of the current time:
var d = new Date();
document.write(d.getUTCMinutes()) The output of the code above will be:
|
Example №2
Here we will extract the UTC minutes from the specific date and time:
var born = new Date("July 21, 1983 01:15:00");
document.write(born.getUTCMinutes()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getUTCSeconds() |
Returns the seconds of a Date object according to universal time (from 0-59)
Note:
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example №1
In this example we get the UTC seconds of the current time:
var d = new Date();
document.write(d.getUTCSeconds()) The output of the code above will be:
|
Example №2
Here we will extract the UTC seconds from the specific date and time:
var born = new Date("July 21, 1983 01:15:00");
document.write(born.getUTCSeconds()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
getUTCMilliseconds() |
Returns the milliseconds of a Date object according to universal time (from 0-999)
Note:
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example №1
In this example we get the UTC milliseconds of the current time:
var d = new Date();
document.write(d.getUTCMilliseconds()) The output of the code above will be:
|
Example №2
Here we will extract the UTC milliseconds from the specific date and time:
var born = new Date("July 21, 1983 01:15:00");
document.write(born.getUTCMilliseconds()) The output of the code above will be:
Note: The code above will set the milliseconds to 0, since no milliseconds was defined in the date.
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
parse(datestring) |
Takes a date string and returns the number of milliseconds since midnight of January 1, 1970
Argument:
|
Example №1
In this example we will get how many milliseconds there are from 1970/01/01 to 2005/07/08:
var d = Date.parse("Jul 8, 2005");
document.write(d) The output of the code above will be:
|
Example №2
Now we will convert the output from the example above into years:
var minutes = 1000 * 60; var hours = minutes * 60;
var days = hours * 24; var years = days * 365; var t = Date.parse("Jul 8, 2005"); var y = t/years; document.write("It's been: " + y + " years from 1970/01/01"); document.write(" to 2005/07/08!") The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setDate() |
Sets the day of the month in a Date object (from 1-31)
Arguments:
Note:
|
Example №
In this example we set the day of the current month to 15 with the setDate() method:
var d = new Date();
d.setDate(15); document.write(d); The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setMonth(month,day) |
Sets the month in a Date object (from 0-11)
Arguments:
Note:
|
Example №1
In this example we set the month to 0 (January) with the setMonth() method:
var d=new Date();
d.setMonth(0); document.write(d) The output of the code above will be:
|
Example №2
In this example we set the month to 0 (January) and the day to 20 with the setMonth() method:
var d=new Date();
d.setMonth(0,20); document.write(d) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setFullYear(year,month,day) |
Sets the year in a Date object (four digits)
Arguments:
Note: This method is always used in conjunction with a Date object.
|
Example №1
In this example we set the year to 1992 with the setFullYear() method:
var d = new Date();
d.setFullYear(1992); document.write(d) The output of the code above will be:
|
Example №2
In this example we set the date to November 3, 1992 with the setFullYear() method:
var d = new Date();
d.setFullYear(1992,10,3); document.write(d) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setHours(hour,min,sec,millisec) |
Sets the hour in a Date object (from 0-23)
Argument:
Note:
|
Example
In this example we set the hour of the current time to 15, with the setHours() method:
var d = new Date();
d.setHours(15); document.write(d) The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setMinutes(min,sec,millisec) |
Set the minutes in a Date object (from 0-59)
Argument:
Note:
|
Example
In this example we set the minutes of the current time to 01, with the setMinutes() method:
var d = new Date();
d.setMinutes(1); document.write(d) The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setSeconds(sec,millisec) |
Sets the seconds in a Date object (from 0-59)
Argument:
Note:
|
Example
In this example we set the seconds of the current time to 01, with the setSeconds() method:
var d = new Date();
d.setSeconds(1); document.write(d) The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setMilliseconds(millisec) |
Sets the milliseconds in a Date object (from 0-999)
Argument:
Note:
|
Example
In this example we set the milliseconds of the current time to 001, with the setMilliseconds() method:
var d = new Date();
d.setMilliseconds(1); document.write(d) The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setTime(millisec) |
Calculates a date and time by adding or subtracting a specified number of milliseconds to/from midnight January 1, 1970
Argument:
Note: This method is always used in conjunction with a Date object.
|
Example №1
In this example we will add 77771564221 milliseconds to 1970/01/01 and display the new date and time:
var d = new Date();
d.setTime(77771564221); document.write(d); The output of the code above will be:
|
Example №2
In this example we will subtract 77771564221 milliseconds from 1970/01/01 and display the new date and time:
var d = new Date();
d.setTime(-77771564221); document.write(d) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setUTCDate(day) |
Sets the day of the month in a Date object according to universal time (from 1-31)
Argument:
Note: This method is always used in conjunction with a Date object.
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example
In this example we set the day of the current month to 15 with the setUTCDate() method:
var d = new Date();
d.setUTCDate(15); document.write(d) The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setUTCMonth(month,day) |
Sets the month in a Date object according to universal time (from 0-11)
Arguments:
Note: This method is always used in conjunction with a Date object.
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example №1
In this example we set the month to 0 (January) with the setUTCMonth() method:
var d = new Date();
d.setUTCMonth0); document.write(d) The output of the code above will be:
|
Example №2
In this example we set the month to 0 (January) and the day to 20 with the setUTCMonth() method:
var d = new Date();
d.setUTCMonth(0,20); document.write(d) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setUTCFullYear(year,month,day) |
Sets the year in a Date object according to universal time (four digits)
Arguments:
Note: This method is always used in conjunction with a Date object.
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example №1
In this example we set the year to 1992 with the setUTCFullYear() method:
var d = new Date();
d.setUTCFullYear(1992); document.write(d) The output of the code above will be:
|
Example №2
In this example we set the date to November 3, 1992 with the setUTCFullYear() method:
var d = new Date();
d.setUTCFullYear(1992,10,3); document.write(d) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setUTCHours (hour,min,sec,millisec) |
Sets the hour in a Date object according to universal time (from 0-23)
Arguments:
Note:
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example
In this example we set the seconds of the current time to 01, with the setUTCSeconds() method:
var d = new Date();
d.setUTCHours(1); document.write(d) The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setUTCMinutes(min,sec,millisec) |
Set the minutes in a Date object according to universal time (from 0-59)
Arguments:
Note:
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example
In this example we set the seconds of the current time to 01, with the setUTCSeconds() method:
var d = new Date();
d.setUTCMinutes(1); document.write(d) The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setUTCSeconds(sec,millisec) |
Set the seconds in a Date object according to universal time (from 0-59)
Arguments:
Note:
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example
In this example we set the seconds of the current time to 01, with the setUTCSeconds() method:
var d = new Date();
d.setUTCSeconds(1); document.write(d) The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
setUTCMilliseconds(millisec) |
Sets the milliseconds in a Date object according to universal time (from 0-999)
Argument:
Note
Tip: The Universal Coordinated Time (UTC) is the time set by the World Time Standard.
|
Example
In this example we set the milliseconds of the current time to 001, with the setUTCMilliseconds() method:
var d = new Date();
d.setUTCMilliseconds(1); document.write(d) The output of the code above will be:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
toUTCString() | Converts a Date object, according to universal time, to a string |
Example №1
In the example below we will convert today's date (according to UTC) to a string:
var d = new Date();
document.write (d.toUTCString()) The output of the code above will be:
|
Example №2
In the example below we will convert a specific date (according to UTC) to a string:
var born = new Date("December 29, 1970 00:30:00");
document.write(born.toUTCString()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
toLocaleString() | Converts a Date object, according to local time, to a string |
Example №1
In the example below we will convert today's date (according to local time) to a string:
var d = new Date();
document.write(d.toLocaleString()) The output of the code above will be:
|
Example №2
In the example below we will convert a specific date (according to local time) to a string:
var born = new Date("December 29, 1970 00:30:00");
document.write(born.toLocaleString()) The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
UTC (year,month,day, hours,minutes,seconds,ms) |
Takes a date and returns the number of milliseconds since midnight of January 1, 1970 according to universal time
Arguments
|
Example №1
In this example we will get how many milliseconds there are from 1970/01/01 to 2005/07/08 according to universal time:
var d = Date.UTC(2005,7,8);
document.write(d) The output of the code above will be:
|
Example №2
Now we will convert the output from the example above into years:
var minutes = 1000*60;
var hours = minutes*60; var days = hours*24; var years = days*365; var t = Date.UTC(2005,7,8); var y = t/years; document.write("It's been: " + y + " years from 1970/01/01"); document.write(" to 2005/07/08!") The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Function Object Description | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
The built-in Function object specifies a string of JavaScript code to be compiled as a function.
To create a Function object:
functionObjectName = new Function ([arg1, arg2, ... argn], functionBody)
Arguments:
Function objects are evaluated each time they are used. This is less efficient than declaring a function and calling it
within your code, because declared functions are compiled.
In addition to defining functions as described here, you can also use the function statement, as described in "function".
The following code assigns a function to the variable setBGColor. This function sets the current document's background color.
var setBGColor = new Function("document.bgColor='antiquewhite'")
To call the Function object, you can specify the variable name as if it were a function.
The following code executes the function specified by the setBGColor variable:
var colorChoice="antiquewhite"
if (colorChoice=="antiquewhite") {setBGColor()} You can assign the function to an event handler in either of the following ways:
Creating the variable setBGColor shown above is similar to declaring the following function:
function setBGColor() {
document.bgColor='antiquewhite' } Assigning a function to a variable is similar to declaring a function, but they have differences:
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Image Object Description | JavaScript Image Object Properties | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
To create an Image object:
imageName = new Image([width, height])
To use an Image object's properties:
To define an event handler for an Image object created with the Image() constructor:
The position and size of an image in a document are set when the document is displayed
in Navigator and cannot be changed using JavaScript (the width and height properties are read-only).
You can change which image is displayed by setting the src and lowsrc properties. (See the descriptions of src and lowsrc.)
You can use JavaScript to create an animation with an Image object by repeatedly setting the src property.
JavaScript animation is slower than GIF animation, because with GIF animation the entire animation is in one file; with JavaScript animation,
each frame is in a separate file, and each file must be loaded across the network (host contacted and data transferred).
Image objects do not have onClick, onMouseOut, and onMouseOver event handlers. However, if you define an Area object for the image
or place the <img> tag within a Link object, you can use the Area or Link object's event handlers. See the Link object.
The Image() constructor
The primary use for an Image object created with the Image() constructor is to load an image from the network (and decode it)
before it is actually needed for display. Then when you need to display the image within an existing image cell, you can set the src property of
the displayed image to the same value as that used for the prefetched image, as follows.
myImage = new Image()
myImage.src = "seaotter.gif" ... document.images[0].src = myImage.src The resulting image will be obtained from cache, rather than loaded over the network, assuming that sufficient time has elapsed
to load and decode the entire image. You can use this technique to create smooth animations,
or you could display one of several images based on form input.
|
border | Reflects the BORDER attribute | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
complete | Boolean value indicating whether Navigator has completed its attempt to load the image | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
height | Reflects the HEIGHT attribute | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
hspace | Reflects the HSPACE attribute | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
lowsrc | Reflects the LOWSRC attribute | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
name | Reflects the NAME attribute | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
src | Reflects the SRC attribute | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
vspace | Reflects the VSPACE attribute | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
width | Reflects the WIDTH attribute | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Math Object Description | JavaScript Math Object Properties | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
The built-in Math object has properties and methods for mathematical constants and functions.
For example, the Math object's PI property has the value of pi (3.141...), which you would use in an application as
Math.PI
Similarly, standard mathematical functions are methods of Math. These include trigonometric, logarithmic,
exponential, and other functions. For example, if you want to use the trigonometric function sine, you would write
Math.sin(1.56)
Note:
Trigonometric methods of Math take arguments in radians.
It is often convenient to use the with statement when a section of code uses several math constants and methods,
so you don't have to type "Math" repeatedly. For example,
with (Math) {
a = PI*r*r y = r*sin(theta) x = r*cos(theta) } |
E | Returns Euler's constant (approx. 2.718) | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
LN2 | Returns the natural logarithm of 2 (approx. 0.693) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
LN10 | Returns the natural logarithm of 10 (approx. 2.302) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
LOG2E | Returns the base-2 logarithm of E (approx. 1.442) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
LOG10E | Returns the base-10 logarithm of E (approx. 0.434) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
PI | Returns PI (approx. 3.14159) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
SQRT1_2 | Returns the square root of 1/2 (approx. 0.707) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
SQRT2 | Returns the square root of 2 (approx. 1.414) | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Math Object Methods | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
abs(x) | Returns the absolute value of a number | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
acos(x) | Returns the arccosine of a number | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
asin(x) | Returns the arcsine of a number | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
atan(x) | Returns the arctangent of x as a numeric value between -PI/2 and PI/2 radians | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
atan2(y,x) | Returns the angle theta of an (x,y) point as a numeric value between -PI and PI radians | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
ceil(x) | Returns the value of a number rounded upwards to the nearest integer | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
cos(x) | Returns the cosine of a number | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
exp(x) | Returns the value of Ex | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
floor(x) | Returns the value of a number rounded downwards to the nearest integer | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
log(x) | Returns the natural logarithm (base E) of a number | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
max(x,y) | Returns the number with the highest value of x and y | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
min(x,y) | Returns the number with the lowest value of x and y | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
pow(x,y) | Returns the value of x to the power of y | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
random() | Returns a random number between 0 and 1 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
round(x) | Rounds a number to the nearest integer | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
sin(x) | Returns the sine of a number | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
sqrt(x) | Returns the square root of a number | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
tan(x) | Returns the tangent of an angle | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Number Object Description | JavaScript Number Object Properties | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
The Number object has properties for numerical constants, such as maximum value, not-a-number, and infinity. You use these properties as follows:
biggestNum = Number.MAX_VALUE
smallestNum = Number.MIN_VALUE infiniteNum = Number.POSITIVE_INFINITY negInfiniteNum = Number.NEGATIVE_INFINITY notANum = Number.NaN |
MAX_VALUE | The largest representable number | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
MIN_VALUE | The smallest representable number | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
NaN | Special "not a number" value | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
NEGATIVE_INFINITY | Special infinite value; returned on overflow | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
POSITIVE_INFINITY | Special negative infinite value; returned on overflow | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript String Object Description | JavaScript String Object Properties | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript does not have a string data type. However, you can use the String object and its methods to work with strings in your applications.
The String object has a large number of methods for manipulating strings. It has one property for determining the string's length.
To create a String object:
stringObjectName = new String(string)
Arguments:
For example, the following statement creates a String object called mystring:
mystring = new String ("Hello, World!")
String literals are also String objects; for example, the literal "Howdy" is a String object.
A String object has one property, length, that indicates the number of characters in the string. So, using the previous example, the expression
x = mystring.length
assigns a value of 13 to x, because "Hello, World!" has 13 characters.
A String object has two types of methods: those that return a variation on the string itself, such as substring and toUpperCase,
and those that return an HTML-formatted version of the string, such as bold and link.
For example, using the previous example, both mystring.toUpperCase() and "hello, world!".toUpperCase() return the string "HELLO, WORLD!".
The substring method takes two arguments and returns a subset of the string between the two arguments. Using the previous example,
mystring.substring(4, 9) returns the string "o, Wo." For more information, see the reference topic for substring.
The String object also has a number of methods for automatic HTML formatting, such as bold to create boldface text and
link to create a hyperlink. For example, you could create a hyperlink to a hypothetical URL with the link method as follows:
mystring.link("http://www.helloworld.com")
|
length | Returns the number of characters in a string |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript String Object Methods | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
anchor(anchorname) |
Creates an HTML anchor
Argument:
|
In this example we will add an anchor to a text:
var txt="Hello world!";
document.write(txt.anchor("myanchor")) The code above could be written in plain HTML, like this:
<a name="myanchor">Hello world!</a>
|
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
big() | Displays a string in a big font |
In this example "Hello world!" will be displayed in a big font:
var str="Hello world!";
document.write(str.big()); |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
blink() |
Displays a blinking string
Note: This method does not work in Internet Explorer.
|
var str="Hello world!";
document.write(str.blink()); |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
bold() | Displays a string in bold |
In this example "Hello world!" will be displayed in bold:
var str="Hello world!";
document.write(str.bold()) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
charAt(index) |
Returns the character at a specified position
Argument:
Note: The first character in the string is at position 0.
|
In the string "Hello world!", we will return the character at position 1:
var str="Hello world!";
document.write(str.charAt(1)) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
charCodeAt(index) |
Returns the Unicode of the character at a specified position
Argument:
Note: The first character in the string is at position 0.
|
In the string "Hello world!", we will return the Unicode of the character at position 1:
var str="Hello world!";
document.write(str.charCodeAt(1)) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
concat(stringX,stringX,...,stringX) |
Joins two or more strings
Argument:
|
In the following example we will create two strings and show them as one using concat():
var str1="Hello ";
var str2="world!"; document.write(str1.concat(str2)); |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
fixed() | Displays a string as teletype text |
In this example "Hello world!" will be displayed as teletype text:
var str="Hello world!";
document.write(str.fixed()) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
fontcolor(color) |
Displays a string in a specified color
Argument:
|
In this example "Hello world!" will be displayed in red:
var str="Hello world!";
document.write(str.fontcolor("Red")) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
fontsize(size) |
Displays a string in a specified size
Argument:
Note: The size parameter must be a number from 1 to 7.
|
In this example "Hello world!" will be displayed in a large font-size:
var str="Hello world!";
document.write(str.fontsize(7)) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
fromCharCode(numX,numX,...,numX) |
Takes the specified Unicode values and returns a string
Argument:
Note: This method is a static method of String - it is not used as a method of
a String object that you have created. The syntax is always String.fromCharCode() and not myStringObject.fromCharCode().
|
In this example we will write "HELLO" and "ABC" from Unicode:
document.write(String.fromCharCode(72,69,76,76,79));
document.write("<br />"); document.write(String.fromCharCode(65,66,67)) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
indexOf(searchvalue,fromindex) |
Returns the position of the first occurrence of a specified string value in a string
Arguments:
Notes:
|
In this example we will do different searches within a "Hello world!" string:
var str="Hello world!";
document.write(str.indexOf("Hello") + "<br />"); document.write(str.indexOf("World") + "<br />"); document.write(str.indexOf("world")); |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
italics() | Displays a string in italic |
In this example "Hello world!" will be displayed in italic:
var str="Hello world!";
document.write(str.italics()) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
lastIndexOf(searchvalue,fromindex) |
Returns the position of the last occurrence of a specified string value, searching backwards
from the specified position in a string
Arguments:
Notes:
|
In this example we will do different searches within a "Hello world!" string:
var str="Hello world!";
document.write(str.lastIndexOf("Hello") + "<br />"); document.write(str.lastIndexOf("World") + "<br />"); document.write(str.lastIndexOf("world")) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
link() | Displays a string as a hyperlink |
In this example "Free Web Tutorials!" will be displayed as a hyperlink:
var str="Free Web Manuals!";
document.write(str.link("http://www.cheat-sheets.org/")) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
match(searchvalue) |
Searches for a specified string value in a string
This method is similar to indexOf() and lastIndexOf(), but it returns the specified string, instead of the position of the string.
Argument:
Notes:
|
var str="Hello world!";
document.write(str.match("world") + "<br />"); document.write(str.match("World") + "<br />"); document.write(str.match("worlld") + "<br />"); document.write(str.match("world!")) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
replace(findstring,newstring) |
Replaces some characters with some other characters in a string
Arguments:
Note:
|
In the following example we will replace the word Microsoft with MANUALS.SU:
var str="Visit Microsoft!";
document.write(str.replace(/Microsoft/, "MANUALS.SU")) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
search(searchstring) |
Searches a string for a specified value
Argument:
Notes:
|
In the following example we will search for the word "MANUALS.SU":
var str="Visit MANUALS.SU!";
document.write(str.search(/MANUALS.SU/)) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
slice(start,end) |
Extracts a part of a string and returns the extracted part in a new string
Argument:
Notes:
|
In this example we will extract all characters from a string, starting at position 6:
var str="Hello happy world!";
document.write(str.slice(6)) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
small() | Displays a string in a small font |
In this example "Hello world!" will be displayed in a small font:
var str="Hello world!";
document.write(str.small()) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
split(separator, howmany) |
Splits a string into an array of strings
Arguments:
Note:
|
In this example we will split up a string in different ways:
var str="How are you doing today?";
document.write(str.split(" ") + "<br />"); document.write(str.split("") + "<br />"); document.write(str.split(" ",3)) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
strike() | Displays a string with a strikethrough |
In this example "Hello world!" will be displayed with a line trough it:
var str="Hello world!";
document.write(str.strike()) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
sub() | Displays a string as subscript |
In this example "Hello world!" will be displayed in subscript:
var str="Hello world!";
document.write(str.sub()) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
substr(start,length) |
Extracts a specified number of characters in a string, from a start index
Arguments:
Notes:
|
In this example we will use substr() to extract some characters from a string:
var str="Hello world!";
document.write(str.substr(3)) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
substring(start,stop) |
Extracts the characters in a string between two specified indices
Arguments:
Notes:
|
In this example we will use substring() to extract some characters from a string:
var str="Hello world!";
document.write(str.substring(3)) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
sup() | Displays a string as superscript |
In this example "Hello world!" will be displayed in superscript:
var str="Hello world!";
document.write(str.sup()) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
toLowerCase() | Displays a string in lowercase letters |
In this example "Hello world!" will be displayed in lower case letters:
var str="Hello World!";
document.write(str.toLowerCase()) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
toUpperCase() | Displays a string in uppercase letters |
In this example "Hello world!" will be displayed in upper case letters:
var str="Hello world!";
document.write(str.toUpperCase()) |
The output of the code above will be:
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
JavaScript Event | Other | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onabort | Loading of an image is interrupted |
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onblur | An element loses focus | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onchange | The content of a field changes | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onclick | Mouse clicks an object | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
ondblclick | Mouse double-clicks an object | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onerror | An error occurs when loading a document or an image | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onfocus | An element gets focus | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onkeydown | A keyboard key is pressed | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onkeypress | A keyboard key is pressed or held down | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onkeyup | A keyboard key is released | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onload | A page or an image is finished loading | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onmousedown | A mouse button is pressed | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onmousemove | The mouse is moved | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onmouseout | The mouse is moved off an element | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onmouseover | The mouse is moved over an element | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onmouseup | A mouse button is released | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onreset | The reset button is clicked | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onresize | A window or frame is resized | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onselect | Text is selected | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onsubmit | The submit button is clicked | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
onunload | The user exits the page | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||