Core JavaScript
Core JavaScript
Core JavaScript
sys
TCP/IP
directory server
World Wide Web
ww
Personal
IStore
Proxy
merchant system
HTML
http://www
Internet
server
security
news
URL
HTML
mail
Inter
navigator
electronic commerce
community system
JavaScript
Proxy
Mozilla
certificate
Publishing
Publishing
Chat
encryption
secure sockets layer
SSL
Core JavaScript
Reference
October 29, 1998
Version 1.4
Netscape Communications Corporation ("Netscape") and its licensors retain all ownership rights to the software
programs offered by Netscape (referred to herein as "Software") and related documentation. Use of the Software and
related documentation is governed by the license agreement accompanying the Software and applicable copyright
law.
Your right to copy this documentation is limited by copyright law. Making unauthorized copies, adaptations, or
compilation works is prohibited and constitutes a punishable violation of the law. Netscape may revise this
documentation from time to time without notice.
THIS DOCUMENTATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. IN NO EVENT SHALL
NETSCAPE BE LIABLE FOR ANY LOSS OF PROFITS, LOSS OF BUSINESS, LOSS OF USE OR DATA,
INTERRUPTION
OF BUSINESS, OR FOR INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES OF ANY KIND,
ARISING FROM ANY ERROR IN THIS DOCUMENTATION.
The Software and documentation are copyright ©1994-1998 Netscape Communications Corporation. All rights
reserved.
The Software contains JavaScript software technology invented and implemented by Netscape Communications
Corporation. The JavaScript name is a trademark or registered trademark of Sun Microsystems, Inc. in the United
States and other countries and is used under license.
Netscape, Netscape Navigator, Netscape Certificate Server, Netscape DevEdge, Netscape FastTrack Server, Netscape
ONE, SuiteSpot and the Netscape N and Ship’s Wheel logos are registered trademarks of Netscape Communications
Corporation in the United States and other countries. Other Netscape logos, product names, and service names are
also trademarks of Netscape Communications Corporation, which may be registered in other countries. Other product
and brand names are trademarks of their respective owners.
The downloading, export or reexport of Netscape software or any underlying information or technology must be in
full compliance with all United States and other applicable laws and regulations. Any provision of Netscape software
or documentation to the U.S. Government is with restricted rights as described in the license agreement
accompanying Netscape software.
.
Version 1.4
©1998 Netscape Communications Corporation. All Rights Reserved
Printed in the United States of America. 00 99 98 5 4 3 2 1
Netscape Communications Corporation, 501 East Middlefield Road, Mountain View, CA 94043
Recycled and Recyclable Paper
3
Contents
New Features in this Release .......................................................................3
About this Book ................................................................................................9
New Features in this Release ................................................................................9
What You Should Already Know .........................................................................9
JavaScript Versions ..............................................................................................10
Where to Find JavaScript Information ................................................................11
Document Conventions .......................................................................................12
Part 1 Object Reference
Chapter 1 Objects, Methods, and Properties ......................................15
Array .....................................................................................................................16
Boolean ................................................................................................................38
Date ......................................................................................................................43
Function ...............................................................................................................79
java .......................................................................................................................97
JavaArray ..............................................................................................................98
JavaClass .............................................................................................................102
JavaObject ..........................................................................................................104
JavaPackage .......................................................................................................106
Math ....................................................................................................................107
netscape .............................................................................................................126
Number ..............................................................................................................127
Object .................................................................................................................136
Packages .............................................................................................................147
RegExp ...............................................................................................................151
String ..................................................................................................................173
sun ......................................................................................................................210
vi Core JavaScript Reference
Chapter 2 Top-Level Properties and Functions .............................. 211
escape ................................................................................................................ 212
eval .................................................................................................................... 214
Infinity ............................................................................................................... 216
isFinite ............................................................................................................... 217
isNaN ................................................................................................................. 218
NaN .................................................................................................................... 218
Number .............................................................................................................. 219
parseFloat .......................................................................................................... 220
parseInt .............................................................................................................. 221
String .................................................................................................................. 223
undefined .......................................................................................................... 223
unescape ............................................................................................................ 224
Part 2 Language Elements
Chapter 3 Statements ................................................................................ 229
break .................................................................................................................. 231
comment ............................................................................................................ 232
continue ............................................................................................................. 233
do...while ........................................................................................................... 234
export ................................................................................................................ 235
for ....................................................................................................................... 235
for...in ................................................................................................................ 236
function .............................................................................................................. 237
if...else ................................................................................................................ 238
import ................................................................................................................ 239
label ................................................................................................................... 240
return ................................................................................................................. 241
switch ................................................................................................................. 241
throw ................................................................................................................. 243
try...catch ........................................................................................................... 246
var ...................................................................................................................... 248
while .................................................................................................................. 248
with .................................................................................................................... 249
Contents vii
Chapter 4 Operators ................................................................................. 251
Assignment Operators ....................................................................................... 254
Comparison Operators ...................................................................................... 256
Using the Equality Operators ....................................................................... 257
Arithmetic Operators ......................................................................................... 259
% (Modulus) .................................................................................................. 259
++ (Increment) .............................................................................................. 259
-- (Decrement) .............................................................................................. 260
- (Unary Negation) ....................................................................................... 260
Bitwise Operators .............................................................................................. 260
Bitwise Logical Operators ............................................................................ 261
Bitwise Shift Operators ................................................................................. 262
Logical Operators .............................................................................................. 263
String Operators ................................................................................................ 266
Special Operators .............................................................................................. 266
?: (Conditional operator) .............................................................................. 266
, (Comma operator) ...................................................................................... 267
delete ............................................................................................................. 267
in .................................................................................................................... 269
instanceof ...................................................................................................... 270
new ................................................................................................................ 272
this ................................................................................................................. 274
typeof ............................................................................................................ 275
void ............................................................................................................... 276
Part 3 LiveConnect Class Reference
Chapter 5 Java Classes, Constructors, and Methods ..................... 279
JSException ........................................................................................................ 280
JSObject ............................................................................................................. 282
Part 4 Appendixes
Appendix A Reserved Words .................................................................. 289
Index ................................................................................................................ 291
viii Core JavaScript Reference
9
JavaScript Versions
Each version of Navigator supports a different version of JavaScript. To help
you write scripts that are compatible with multiple versions of Navigator, this
manual lists the JavaScript version in which each feature was implemented.
The following table lists the JavaScript version supported by different Navigator
versions. Versions of Navigator prior to 2.0 do not support JavaScript.
Each version of the Netscape Enterprise Server also supports a different version
of JavaScript. To help you write scripts that are compatible with multiple
versions of the Enterprise Server, this manual uses an abbreviation to indicate
the server version in which each feature was implemented.
Table 1 JavaScript and Navigator versions
JavaScript version Navigator version
JavaScript 1.0 Navigator 2.0
JavaScript 1.1 Navigator 3.0
JavaScript 1.2 Navigator 4.0–4.05
JavaScript 1.3 Navigator 4.06–4.5
JavaScript 1.4
Table 2 JavaScript and Netscape Enterprise Server versions
Abbreviation Enterpriser Server version
NES 2.0 Netscape Enterprise Server 2.0
NES 3.0 Netscape Enterprise Server 3.0
11
Where to Find JavaScript Information
Document Conventions
JavaScript applications run on many operating systems; the information in this
book applies to all versions. File and directory paths are given in Windows
format (with backslashes separating directory names). For Unix versions, the
directory paths are the same, except that you use slashes instead of backslashes
to separate directories.
This book uses uniform resource locators (URLs) of the following form:
http:// server.domain/ path/ file.html
In these URLs, server represents the name of the server on which you run your
application, such as research1 or www; domain represents your Internet
domain name, such as netscape.com or uiuc.edu; path represents the
directory structure on the server; and file.html represents an individual file
name. In general, items in italics in URLs are placeholders and items in normal
monospace font are literals. If your server has Secure Sockets Layer (SSL)
enabled, you would use https instead of http in the URL.
This book uses the following font conventions:
• The monospace font is used for sample code and code listings, API and
language elements (such as method names and property names), file
names, path names, directory names, HTML tags, and any text that must be
typed on the screen. ( Monospace italic font is used for placeholders
embedded in code.)
• Italic type is used for book titles, emphasis, variables and placeholders, and
words used in the literal sense.
Boldface type is used for glossary terms.
1
• Objects, Methods, and
Properties
• Top-Level Properties and
Functions
Object Reference
This chapter documents all the JavaScript objects, along with their methods and
properties. It is an alphabetical reference for the main features of JavaScript.
The reference is organized as follows:
• Full entries for each object appear in alphabetical order; properties and
functions not associated with any object appear in Chapter 2, “Top-Level
Properties and Functions.”
Each entry provides a complete description for an object. Tables included
in the description of each object summarize the object’s methods and
properties.
• Full entries for an object’s methods and properties appear in alphabetical
order after the object’s entry.
These entries provide a complete description for each method or property,
and include cross-references to related features in the documentation.
Array
16 Core JavaScript Reference
Array
Lets you work with arrays.
Created by The Array object constructor:
new Array( arrayLength)
new Array( element0, element1, ..., elementN)
An array literal:
[ element0, element1, ..., elementN]
JavaScript 1.2 when you specify LANGUAGE="JavaScript1.2" in the
<SCRIPT> tag:
new Array( element0, element1, ..., elementN)
JavaScript 1.2 when you do not specify LANGUAGE="JavaScript1.2" in the
<SCRIPT> tag:
new Array([ arrayLength])
new Array([ element0[, element1[, ..., elementN]]])
JavaScript 1.1:
new Array([ arrayLength])
new Array([ element0[, element1[, ..., elementN]]])
Parameters
Core object
Implemented in JavaScript 1.1, NES 2.0
JavaScript 1.3: added toSource method
ECMA version ECMA-262
arrayLength The initial length of the array. You can access this value using the
length property. If the value specified is not a number, an array of
length 1 is created, with the first element having the specified value.
The maximum length allowed for an array is 4,294,967,295.
element N A list of values for the array’s elements. When this form is specified,
the array is initialized with the specified values as its elements, and
the array’s length property is set to the number of arguments.
Chapter 1, Objects, Methods, and Properties 17
Array
Description An array is an ordered set of values associated with a single variable name.
The following example creates an Array object with an array literal; the
coffees array contains three elements and a length of three:
coffees = ["French Roast", "Columbian", "Kona"]
Indexing an array. You index an array by its ordinal number. For example,
assume you define the following array:
myArray = new Array("Wind","Rain","Fire")
You then refer to the first element of the array as myArray[0] and the second
element of the array as myArray[1].
Specifying a single parameter. When you specify a single numeric parameter
with the Array constructor, you specify the initial length of the array. The
following code creates an array of five elements:
billingMethod = new Array(5)
The behavior of the Array constructor depends on whether the single
parameter is a number.
• If the value specified is a number, the constructor converts the number to
an unsigned, 32-bit integer and generates an array with the length
property (size of the array) set to the integer. The array initially contains no
elements, even though it might have a non-zero length.
• If the value specified is not a number, an array of length 1 is created, with
the first element having the specified value.
The following code creates an array of length 25, then assigns values to the first
three elements:
musicTypes = new Array(25)
musicTypes[0] = "R&B"
musicTypes[1] = "Blues"
musicTypes[2] = "Jazz"
You can construct a dense array of two or more elements starting with index 0
if you define initial values for all elements. A dense array is one in which each
element has a value. The following code creates a dense array with three
elements:
myArray = new Array("Hello", myVar, 3.14159)
Array
18 Core JavaScript Reference
Increasing the array length indirectly. An array’s length increases if you
assign a value to an element higher than the current length of the array. The
following code creates an array of length 0, then assigns a value to element 99.
This changes the length of the array to 100.
colors = new Array()
colors[99] = "midnightblue"
Creating an array using the result of a match. The result of a match
between a regular expression and a string can create an array. This array has
properties and elements that provide information about the match. An array is
the return value of RegExp.exec, String.match, and String.replace.
To help explain these properties and elements, look at the following example
and then refer to the table below:
<SCRIPT LANGUAGE="JavaScript1.2">
//Match one d followed by one or more b’s followed by one d
//Remember matched b’s and the following d
//Ignore case
myRe=/d(b+)(d)/i;
myArray = myRe.exec("cdbBdbsbz");
</SCRIPT>
The properties and elements returned from this match are as follows:
Property/Element Description Example
input A read-only property that reflects the
original string against which the regular
expression was matched.
cdbBdbsbz
index A read-only property that is the zero-based
index of the match in the string.
1
[0] A read-only element that specifies the last
matched characters.
dbBd
[1], ...[n] Read-only elements that specify the
parenthesized substring matches, if
included in the regular expression. The
number of possible parenthesized
substrings is unlimited.
[1]=bB
[2]=d
Chapter 1, Objects, Methods, and Properties 19
Array
Backward
Compatibility
JavaScript 1.2. When you specify a single parameter with the Array
constructor, the behavior depends on whether you specify
LANGUAGE="JavaScript1.2" in the <SCRIPT> tag:
• If you specify LANGUAGE="JavaScript1.2" in the <SCRIPT> tag, a
single-element array is returned. For example, new Array(5) creates a
one-element array with the first element being 5. A constructor with a single
parameter acts in the same way as a multiple parameter constructor. You
cannot specify the length property of an Array using a constructor with
one parameter.
• If you do not specify LANGUAGE="JavaScript1.2" in the <SCRIPT>
tag, you specify the initial length of the array as with other JavaScript
versions.
JavaScript 1.1 and earlier. When you specify a single parameter with the
Array constructor, you specify the initial length of the array. The following
code creates an array of five elements:
billingMethod = new Array(5)
JavaScript 1.0. You must index an array by its ordinal number; for example
myArray[0].
Property
Summary Property Description
constructor Specifies the function that creates an object’s prototype.
index For an array created by a regular expression match, the zero-based
index of the match in the string.
input For an array created by a regular expression match, reflects the
original string against which the regular expression was matched.
length Reflects the number of elements in an array
prototype Allows the addition of properties to all objects.
Array
20 Core JavaScript Reference
Method Summary
In addition, this object inherits the watch and unwatch methods from
Object.
Examples Example 1. The following example creates an array, msgArray, with a length
of 0, then assigns values to msgArray[0] and msgArray[99], changing the
length of the array to 100.
msgArray = new Array()
msgArray[0] = "Hello"
msgArray[99] = "world"
// The following statement is true,
// because defined msgArray[99] element.
if (msgArray.length == 100)
myVar="The length is 100."
Method Description
concat Joins two arrays and returns a new array.
join Joins all elements of an array into a string.
pop Removes the last element from an array and returns that element.
push Adds one or more elements to the end of an array and returns the new
length of the array.
reverse Transposes the elements of an array: the first array element becomes
the last and the last becomes the first.
shift Removes the first element from an array and returns that element
slice Extracts a section of an array and returns a new array.
splice Adds and/or removes elements from an array.
sort Sorts the elements of an array.
toSource Returns an array literal representing the specified array; you can use
this value to create a new array. Overrides the Object.toSource
method.
toString Returns a string representing the array and its elements. Overrides the
Object.toString method.
unshift Adds one or more elements to the front of an array and returns the
new length of the array.
valueOf Returns the primitive value of the array. Overrides the
Object.valueOf method.
Chapter 1, Objects, Methods, and Properties 21
Array.concat
Example 2: Two-dimensional array. The following code creates a twodimensional
array and assigns the results to myVar.
myVar="Multidimensional array test; "
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]
}
myVar += str +"; "
}
This example assigns the following string to myVar (line breaks are used here
for readability):
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];
concat .
Specifies the function that creates an object’s prototype. Note that the value of
this property is a reference to the function itself, not a string containing the
function’s name.
Description See Object.constructor.
Property of Array
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Chapter 1, Objects, Methods, and Properties 23
Array.index
index .
For an array created by a regular expression match, the zero-based index of the
match in the string.
input .
For an array created by a regular expression match, reflects the original string
against which the regular expression was matched.
join .
Removes the last element from an array and returns that element. This method
changes the length of the array.
Syntax pop()
Parameters None.
Example The following code creates the myFish array containing four elements, then
removes its last element.
myFish = ["angel", "clown", "mandarin", "surgeon"];
popped = myFish.pop();
See also push, shift, unshift
prototype .
Represents the prototype for this class. You can use the prototype to add
properties or methods to all instances of a class. For information on prototypes,
see Function.prototype.
Method of Array
Implemented in JavaScript 1.2, NES 3.0
Property of Array
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Array.push
26 Core JavaScript Reference
push .
Adds one or more elements to the end of an array and returns the new length
of the array. This method changes the length of the array.
Syntax push( element1, ..., elementN)
Parameters
Description The behavior of the push method is analogous to the push function in Perl 4.
Note that this behavior is different in Perl 5.
Backward
Compatibility
JavaScript 1.2. The push method returns the last element added to an array.
Example The following code creates the myFish array containing two elements, then
adds two elements to it. After the code executes, pushed contains 4. (In
JavaScript 1.2, pushed contains “lion” after the code executes.)
myFish = ["angel", "clown"];
pushed = myFish.push("drum", "lion");
See also pop, shift, unshift
reverse .
Transposes the elements of an array: the first array element becomes the last
and the last becomes the first.
Syntax reverse()
Parameters None
Method of Array
Implemented in JavaScript 1.2, NES 3.0
JavaScript 1.3: push returns the new length of the array rather than
the last element added to the array.
element1, ...,
element N
The elements to add to the end of the array.
Method of Array
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Chapter 1, Objects, Methods, and Properties 27
Array.shift
Description The reverse method transposes the elements of the calling array object.
Examples 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:
• myArray[0] is “three”
• myArray[1] is “two”
• myArray[2] is “one”
See also Array.join, Array.sort
shift .
Removes the first element from an array and returns that element. This method
changes the length of the array.
Syntax shift()
Parameters None.
Example The following code displays the myFish array before and after removing its first
element. It also displays the removed element:
myFish = ["angel", "clown", "mandarin", "surgeon"];
document.writeln("myFish before: " + myFish);
shifted = myFish.shift();
document.writeln("myFish after: " + myFish);
document.writeln("Removed this element: " + shifted);
This example displays the following:
myFish before: ["angel", "clown", "mandarin", "surgeon"]
myFish after: ["clown", "mandarin", "surgeon"]
Removed this element: angel
See also pop, push, unshift
Method of Array
Implemented in JavaScript 1.2, NES 3.0
Array.slice
28 Core JavaScript Reference
slice .
Changes the content of an array, adding new elements while removing old
elements.
Syntax splice( index, howMany, [element1][, ..., elementN])
Parameters
Description If you specify a different number of elements to insert than the number you’re
removing, the array will have a different length at the end of the call.
The splice method returns an array containing the removed elements. If only
one element is removed, an array of one element is returned
Backward
Compatibility
JavaScript 1.2. The splice method returns the element removed, if only one
element is removed (howMany parameter is 1); otherwise, the method returns
an array containing the removed elements.
Method of Array
Implemented in JavaScript 1.2, NES 3.0
index Index at which to start changing the array.
howMany An integer indicating the number of old array elements to
remove. If howMany is 0, no elements are removed. In this
case, you should specify at least one new element.
element1, ...,
element N
The elements to add to the array. If you don’t specify any
elements, splice simply removes elements from the array.
Array.toSource
34 Core JavaScript Reference
Examples The following script illustrate the use of splice:
<SCRIPT LANGUAGE="JavaScript1.2">
myFish = ["angel", "clown", "mandarin", "surgeon"];
document.writeln("myFish: " + myFish + "<BR>");
removed = myFish.splice(2, 0, "drum");
document.writeln("After adding 1: " + myFish);
document.writeln("removed is: " + removed + "<BR>");
removed = myFish.splice(3, 1)
document.writeln("After removing 1: " + myFish);
document.writeln("removed is: " + removed + "<BR>");
removed = myFish.splice(2, 1, "trumpet")
document.writeln("After replacing 1: " + myFish);
document.writeln("removed is: " + removed + "<BR>");
removed = myFish.splice(0, 2, "parrot", "anemone", "blue")
document.writeln("After replacing 2: " + myFish);
document.writeln("removed is: " + removed);
</SCRIPT>
This script displays:
myFish: ["angel", "clown", "mandarin", "surgeon"]
After adding 1: ["angel", "clown", "drum", "mandarin", "surgeon"]
removed is: undefined
After removing 1: ["angel", "clown", "drum", "surgeon"]
removed is: mandarin
After replacing 1: ["angel", "clown", "trumpet", "surgeon"]
removed is: drum
After replacing 2: ["parrot", "anemone", "blue", "trumpet", "surgeon"]
removed is: ["angel", "clown"]
toSource .
Adds one or more elements to the beginning of an array and returns the new
length of the array.
Syntax arrayName.unshift( element1,..., elementN)
Parameters
Example The following code displays the myFish array before and after adding elements
to it.
myFish = ["angel", "clown"];
document.writeln("myFish before: " + myFish);
unshifted = myFish.unshift("drum", "lion");
document.writeln("myFish after: " + myFish);
document.writeln("New length: " + unshifted);
This example displays the following:
myFish before: ["angel", "clown"]
myFish after: ["drum", "lion", "angel", "clown"]
New length: 4
See also pop, push, shift
Method of Array
Implemented in JavaScript 1.2, NES 3.0
element1,...,
element N
The elements to add to the front of the array.
Chapter 1, Objects, Methods, and Properties 37
Array.valueOf
valueOf .
Boolean
The Boolean object is an object wrapper for a boolean value.
Created by The Boolean constructor:
new Boolean( value)
Parameters
Description Do not confuse the primitive Boolean values true and false with the true and
false values of the Boolean object. Any object whose value is not undefined
or null, including a Boolean object whose value is false, evaluates to true
when passed to a conditional statement. For example, the condition in the
following if statement evaluates to true:
x = new Boolean(false);
if(x) //the condition is true
This behavior does not apply to Boolean primitives. For example, the condition
in the following if statement evaluates to false:
x = false;
if(x) //the condition is false
Do not use a Boolean object to convert a non-boolean value to a boolean
value. Instead, use Boolean as a function to perform this task:
x = Boolean(expression) //preferred
x = new Boolean(expression) //don’t use
Core object
Implemented in JavaScript 1.1, NES 2.0
JavaScript 1.3: added toSource method
ECMA version ECMA-262
value The initial value of the Boolean object. The value is converted to a
boolean value, if necessary. If value is omitted or is 0, -0, null, false, NaN,
undefined, or the empty string (""), the object has an initial value of false.
All other values, including any object or the string "false", create an
object with an initial value of true.
Chapter 1, Objects, Methods, and Properties 39
Boolean
If you specify any object, including a Boolean object whose value is false, as
the initial value of a Boolean object, the new Boolean object has a value of
true.
myFalse=new Boolean(false) // initial value of false
g=new Boolean(myFalse) //initial value of true
myString=new String("Hello") // string object
s=new Boolean(myString) //initial value of true
In JavaScript 1.3 and later versions, do not use a Boolean object in place of a
Boolean primitive.
Backward
Compatibility
JavaScript 1.2 and earlier versions. When a Boolean object is used as the
condition in a conditional test, JavaScript returns the value of the Boolean
object. For example, a Boolean object whose value is false is treated as the
primitive value false, and a Boolean object whose value is true is treated as
the primitive value true in conditional tests. If the Boolean object is a false
object, the conditional statement evaluates to false.
Property
Summary
Method Summary
In addition, this object inherits the watch and unwatch methods from
Object.
Property Description
constructor Specifies the function that creates an object’s prototype.
prototype Defines a property that is shared by all Boolean objects.
Method Description
toSource Returns an object literal representing the specified Boolean
object; you can use this value to create a new object. Overrides
the Object.toSource method.
toString Returns a string representing the specified object. Overrides the
Object.toString method.
valueOf Returns the primitive value of a Boolean object. Overrides the
Object.valueOf method.
Boolean.constructor
40 Core JavaScript Reference
Examples The following examples create Boolean objects with an initial value of false:
bNoParam = new Boolean()
bZero = new Boolean(0)
bNull = new Boolean(null)
bEmptyString = new Boolean("")
bfalse = new Boolean(false)
The following examples create Boolean objects with an initial value of true:
btrue = new Boolean(true)
btrueString = new Boolean("true")
bfalseString = new Boolean("false")
bSuLin = new Boolean("Su Lin")
constructor .
Specifies the function that creates an object’s prototype. Note that the value of
this property is a reference to the function itself, not a string containing the
function’s name.
Description See Object.constructor.
prototype .
Represents the prototype for this class. You can use the prototype to add
properties or methods to all instances of a class. For information on prototypes,
see Function.prototype.
Property of Boolean
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Property of Boolean
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Chapter 1, Objects, Methods, and Properties 41
Boolean.toSource
toSource .
Date
Lets you work with dates and times.
Created by The Date constructor:
new Date()
new Date( milliseconds)
new Date( dateString)
new Date( yr_num, mo_num, day_num
[, hr_num, min_num, sec_num, ms_num])
Versions prior to JavaScript 1.3:
new Date()
new Date( milliseconds)
new Date( dateString)
new Date( yr_num, mo_num, day_num[, hr_num, min_num, sec_num])
Parameters
Core object
Implemented in JavaScript 1.0, NES 2.0
JavaScript 1.1: added prototype property
JavaScript 1.3: removed platform dependencies to provide a
uniform behavior across platforms; added ms_num parameter to
Date constructor; added getFullYear, setFullYear,
getMilliseconds, setMilliseconds, toSource, and UTC
methods (such as getUTCDate and setUTCDate).
ECMA version ECMA-262
milliseconds Integer value representing the number of milliseconds since 1
January 1970 00:00:00.
dateString String value representing a date. The string should be in a
format recognized by the Date.parse method.
yr_num, mo_num,
day_num
Integer values representing part of a date. As an integer value,
the month is represented by 0 to 11 with 0=January and
11=December.
hr_num, min_num,
sec_num, ms_num
Integer values representing part of a date.
Date
44 Core JavaScript Reference
Description If you supply no arguments, the constructor creates a Date object for today’s
date and time according to local time. If you supply some arguments but not
others, the missing arguments are set to 0. If you supply any arguments, you
must supply at least the year, month, and day. You can omit the hours,
minutes, seconds, and milliseconds.
The date is measured in milliseconds since midnight 01 January, 1970 UTC. A
day holds 86,400,000 milliseconds. The Date object range is -100,000,000 days
to 100,000,000 days relative to 01 January, 1970 UTC.
The Date object provides uniform behavior across platforms.
The Date object supports a number of UTC (universal) methods, as well as
local time methods. UTC, also known as Greenwich Mean Time (GMT), refers
to the time as set by the World Time Standard. The local time is the time known
to the computer where JavaScript is executed.
For compatibility with millennium calculations (in other words, to take into
account the year 2000), you should always specify the year in full; for example,
use 1998, not 98. To assist you in specifying the complete year, JavaScript
includes the methods getFullYear, setFullYear, getFullUTCYear, and
setFullUTCYear.
The following example returns the time elapsed between timeA and timeB in
milliseconds.
timeA = new Date();
// Statements here to take some action.
timeB = new Date();
timeDifference = timeB timeA;
Backward
Compatibility
JavaScript 1.2 and earlier. The Date object behaves as follows:
• Dates prior to 1970 are not allowed.
• JavaScript depends on platform-specific date facilities and behavior; the
behavior of the Date object varies from platform to platform.
Property
Summary Property Description
constructor Specifies the function that creates an object’s prototype.
prototype Allows the addition of properties to a Date object.
Chapter 1, Objects, Methods, and Properties 45
Date
Method Summary
Method Description
getDate Returns the day of the month for the specified date
according to local time.
getDay Returns the day of the week for the specified date
according to local time.
getFullYear Returns the year of the specified date according to
local time.
getHours Returns the hour in the specified date according to
local time.
getMilliseconds Returns the milliseconds in the specified date
according to local time.
getMinutes Returns the minutes in the specified date according to
local time.
getMonth Returns the month in the specified date according to
local time.
getSeconds Returns the seconds in the specified date according to
local time.
getTime Returns the numeric value corresponding to the time
for the specified date according to local time.
getTimezoneOffset Returns the time-zone offset in minutes for the current
locale.
getUTCDate Returns the day (date) of the month in the specified
date according to universal time.
getUTCDay Returns the day of the week in the specified date
according to universal time.
getUTCFullYear Returns the year in the specified date according to
universal time.
getUTCHours Returns the hours in the specified date according to
universal time.
getUTCMilliseconds Returns the milliseconds in the specified date
according to universal time.
getUTCMinutes Returns the minutes in the specified date according to
universal time.
getUTCMonth Returns the month according in the specified date
according to universal time.
Date
46 Core JavaScript Reference
getUTCSeconds Returns the seconds in the specified date according to
universal time.
getYear Returns the year in the specified date according to
local time.
parse Returns the number of milliseconds in a date string
since January 1, 1970, 00:00:00, local time.
setDate Sets the day of the month for a specified date
according to local time.
setFullYear Sets the full year for a specified date according to local
time.
setHours Sets the hours for a specified date according to local
time.
setMilliseconds Sets the milliseconds for a specified date according to
local time.
setMinutes Sets the minutes for a specified date according to local
time.
setMonth Sets the month for a specified date according to local
time.
setSeconds Sets the seconds for a specified date according to local
time.
setTime Sets the value of a Date object according to local time.
setUTCDate Sets the day of the month for a specified date
according to universal time.
setUTCFullYear Sets the full year for a specified date according to
universal time.
setUTCHours Sets the hour for a specified date according to
universal time.
setUTCMilliseconds Sets the milliseconds for a specified date according to
universal time.
setUTCMinutes Sets the minutes for a specified date according to
universal time.
setUTCMonth Sets the month for a specified date according to
universal time.
Method Description
Chapter 1, Objects, Methods, and Properties 47
Date
In addition, this object inherits the watch and unwatch methods from
Object.
Examples The following examples show several ways to assign dates:
today = new Date()
birthday = new Date("December 17, 1995 03:24:00")
birthday = new Date(95,11,17)
birthday = new Date(95,11,17,3,24,0)
setUTCSeconds Sets the seconds for a specified date according to
universal time.
setYear Sets the year for a specified date according to local
time.
toGMTString Converts a date to a string, using the Internet GMT
conventions.
toLocaleString Converts a date to a string, using the current locale’s
conventions.
toSource Returns an object literal representing the specified
Date object; you can use this value to create a new
object. Overrides the Object.toSource method.
toString Returns a string representing the specified Date object.
Overrides the Object.toString method.
toUTCString Converts a date to a string, using the universal time
convention.
UTC Returns the number of milliseconds in a Date object
since January 1, 1970, 00:00:00, universal time.
valueOf Returns the primitive value of a Date object. Overrides
the Object.valueOf method.
Method Description
Date.constructor
48 Core JavaScript Reference
constructor .
Specifies the function that creates an object’s prototype. Note that the value of
this property is a reference to the function itself, not a string containing the
function’s name.
Description See Object.constructor.
getDate .
Returns the day of the month for the specified date according to local time.
Syntax getDate()
Parameters None
Description The value returned by getDate is an integer between 1 and 31.
Examples The second statement below assigns the value 25 to the variable day, based on
the value of the Date object Xmas95.
Xmas95 = new Date("December 25, 1995 23:15:00")
day = Xmas95.getDate()
See also Date.getUTCDate, Date.getUTCDay, Date.setDate
Property of Date
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Method of Date
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
Chapter 1, Objects, Methods, and Properties 49
Date.getDay
getDay .
Returns the day of the week for the specified date according to local time.
Syntax getDay()
Parameters None
Description The value returned by getDay is an integer corresponding to the day of the
week: 0 for Sunday, 1 for Monday, 2 for Tuesday, and so on.
Examples The second statement below assigns the value 1 to weekday, based on the
value of the Date object Xmas95. December 25, 1995, is a Monday.
Xmas95 = new Date("December 25, 1995 23:15:00")
weekday = Xmas95.getDay()
See also Date.getUTCDay, Date.setDate
getFullYear .
Returns the hour for the specified date according to local time.
Syntax getHours()
Parameters None
Description The value returned by getHours is an integer between 0 and 23.
Examples The second statement below assigns the value 23 to the variable hours, based
on the value of the Date object Xmas95.
Xmas95 = new Date("December 25, 1995 23:15:00")
hours = Xmas95.getHours()
See also Date.getUTCHours, Date.setHours
getMilliseconds .
Returns the numeric value corresponding to the time for the specified date
according to local time.
Syntax getTime()
Parameters None
Method of Date
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
Method of Date
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
Chapter 1, Objects, Methods, and Properties 53
Date.getTimezoneOffset
Description The value returned by the getTime method is the number of milliseconds since
1 January 1970 00:00:00. You can use this method to help assign a date and
time to another Date object.
Examples The following example assigns the date value of theBigDay to sameAsBigDay:
theBigDay = new Date("July 1, 1999")
sameAsBigDay = new Date()
sameAsBigDay.setTime(theBigDay.getTime())
See also Date.getUTCHours, Date.setTime
getTimezoneOffset .
Returns the day (date) of the month in the specified date according to universal
time.
Syntax getUTCDate()
Parameters None
Description The value returned by getUTCDate is an integer between 1 and 31.
Method of Date
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
Method of Date
Implemented in JavaScript 1.3
ECMA version ECMA-262
Date.getUTCDay
54 Core JavaScript Reference
Examples The following example assigns the day portion of the current date to the
variable d.
var d;
Today = new Date();
d = Today.getUTCDate();
See also Date.getDate, Date.getUTCDay, Date.setUTCDate
getUTCDay .
Returns the day of the week in the specified date according to universal time.
Syntax getUTCDay()
Parameters None
Description The value returned by getUTCDay is an integer corresponding to the day of
the week: 0 for Sunday, 1 for Monday, 2 for Tuesday, and so on.
Examples The following example assigns the weekday portion of the current date to the
variable ms.
var weekday;
Today = new Date()
weekday = Today.getUTCDay()
See also Date.getDay, Date.getUTCDate, Date.setUTCDate
getUTCFullYear .
getUTCMilliseconds .
Returns the month according in the specified date according to universal time.
Syntax getUTCMonth()
Parameters None
Description The value returned by getUTCMonth is an integer between 0 and 11
corresponding to the month. 0 for January, 1 for February, 2 for March, and so
on.
Examples The following example assigns the month portion of the current date to the
variable mon.
var mon;
Today = new Date();
mon = Today.getUTCMonth();
See also Date.getMonth, Date.setUTCMonth
Method of Date
Implemented in JavaScript 1.3
ECMA version ECMA-262
Date.getUTCSeconds
58 Core JavaScript Reference
getUTCSeconds .
Represents the prototype for this class. You can use the prototype to add
properties or methods to all instances of a class. For information on prototypes,
see Function.prototype.
setDate .
Sets the day of the month for a specified date according to local time.
Syntax setDate( dayValue)
Parameters
Examples The second statement below changes the day for theBigDay to July 24 from its
original value.
theBigDay = new Date("July 27, 1962 23:30:00")
theBigDay.setDate(24)
See also Date.getDate, Date.setUTCDate
Property of Date
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Method of Date
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
dayValue An integer from 1 to 31, representing the day of the month.
Date.setFullYear
62 Core JavaScript Reference
setFullYear .
Sets the full year for a specified date according to local time.
Syntax setFullYear( yearValue[, monthValue, dayValue])
Parameters
Description If you do not specify the monthValue and dayValue parameters, the values
returned from the getMonth and getDate methods are used.
If a parameter you specify is outside of the expected range, setFullYear
attempts to update the other parameters and the date information in the Date
object accordingly. For example, if you specify 15 for monthValue, the year is
incremented by 1 (year + 1), and 3 is used for the month.
Examples theBigDay = new Date();
theBigDay.setFullYear(1997);
See also Date.getUTCFullYear,Date.setUTCFullYear, Date.setYear
Method of Date
Implemented in JavaScript 1.3
ECMA version ECMA-262
yearValue An integer specifying the numeric value of the year, for example,
1995.
monthValue An integer between 0 and 11 representing the months January
through December.
dayValue An integer between 1 and 31 representing the day of the month. If
you specify the dayValue parameter, you must also specify the
monthValue.
Chapter 1, Objects, Methods, and Properties 63
Date.setHours
setHours .
setMilliseconds .
Sets the day of the month for a specified date according to universal time.
Syntax setUTCDate( dayValue)
Parameters
Description If a parameter you specify is outside of the expected range, setUTCDate
attempts to update the date information in the Date object accordingly. For
example, if you use 40 for dayValue, and the month stored in the Date
object is June, the day will be changed to 10 and the month will be
incremented to July.
Method of Date
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
timevalue An integer representing the number of milliseconds since 1 January
1970 00:00:00.
Method of Date
Implemented in JavaScript 1.3
ECMA version ECMA-262
dayValue An integer from 1 to 31, representing the day of the month.
Date.setUTCFullYear
68 Core JavaScript Reference
Examples theBigDay = new Date();
theBigDay.setUTCDate(20);
See also Date.getUTCDate, Date.setDate
setUTCFullYear .
Sets the full year for a specified date according to universal time.
Syntax setUTCFullYear( yearValue[, monthValue, dayValue])
Parameters
Description If you do not specify the monthValue and dayValue parameters, the values
returned from the getMonth and getDate methods are used.
If a parameter you specify is outside of the expected range, setUTCFullYear
attempts to update the other parameters and the date information in the Date
object accordingly. For example, if you specify 15 for monthValue, the year is
incremented by 1 (year + 1), and 3 is used for the month.
Examples theBigDay = new Date();
theBigDay.setUTCFullYear(1997);
See also Date.getUTCFullYear, Date.setFullYear
Method of Date
Implemented in JavaScript 1.3
ECMA version ECMA-262
yearValue An integer specifying the numeric value of the year, for example,
1995.
monthValue An integer between 0 and 11 representing the months January
through December.
dayValue An integer between 1 and 31 representing the day of the month. If
you specify the dayValue parameter, you must also specify the
monthValue.
Chapter 1, Objects, Methods, and Properties 69
Date.setUTCHours
setUTCHours .
setUTCMilliseconds .
setUTCSeconds .
toString .
Function
Specifies a string of JavaScript code to be compiled as a function.
Created by The Function constructor:
new Function ([ arg1[, arg2[, ... argN]],] functionBody)
The function statement (see “function” on page 237 for details):
function name([ param[, param[, ... param]]]) {
statements
}
Parameters
Core object
Implemented in JavaScript 1.1, NES 2.0
JavaScript 1.2: added arity, arguments.callee properties; added
ability to nest functions
JavaScript 1.3: added apply, call, and toSource methods;
deprecated arguments.caller property
JavaScript 1.4: deprecated arguments, arguments.callee,
arguments.length, and arity properties (arguments
remains a variable local to a function rather than a property of
Function)
ECMA version ECMA-262
arg1, arg2,
... arg N
(Optional) Names to be used by the function as formal argument
names. Each must be a string that corresponds to a valid JavaScript
identifier; for example "x" or "theValue".
functionBody A string containing the JavaScript statements comprising the function
definition.
name The function name.
param The name of an argument to be passed to the function. A function can
have up to 255 arguments.
statements The statements comprising the body of the function.
Function
80 Core JavaScript Reference
Description Function objects created with the Function constructor 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.
To return a value, the function must have a return statement that specifies the
value to return.
All parameters are passed to functions by value; 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. However, if you pass an object
as a parameter to a function and the function changes the object’s properties,
that change is visible outside the function, as shown in the following example:
function myFunc(theObject) {
theObject.make="Toyota"
}
mycar = {make:"Honda", model:"Accord", year:1998}
x=mycar.make // returns Honda
myFunc(mycar) // pass object mycar to the function
y=mycar.make // returns Toyota (prop was changed by the function)
The this keyword does not refer to the currently executing function, so you
must refer to Function objects by name, even within the function body.
Accessing a function’s arguments with the arguments array. You can
refer to a function’s arguments within the function by using the arguments
array. See arguments.
Specifying arguments with the Function constructor. The following code
creates a Function object that takes two arguments.
var multiply = new Function("x", "y", "return x * y")
The arguments "x" and "y" are formal argument names that are used in the
function body, "return x * y".
The preceding code assigns a function to the variable multiply. To call the
Function object, you can specify the variable name as if it were a function, as
shown in the following examples.
var theAnswer = multiply(7,6)
var myAge = 50
if (myAge >=39) {myAge=multiply (myAge,.5)}
Chapter 1, Objects, Methods, and Properties 81
Function
Assigning a function to a variable with the Function constructor.
Suppose you create the variable multiply using the Function constructor, as
shown in the preceding section:
var multiply = new Function("x", "y", "return x * y")
This is similar to declaring the following function:
function multiply(x,y) {
return x*y
}
Assigning a function to a variable using the Function constructor is similar to
declaring a function with the function statement, but they have differences:
• When you assign a function to a variable using var multiply = new
Function("..."), multiply is a variable for which the current value is a
reference to the function created with new Function().
• When you create a function using function multiply() {...},
multiply is not a variable, it is the name of a function.
Nesting functions. You can nest a function within a function. The nested
(inner) function is private to its containing (outer) function:
• The inner function can be accessed only from statements in the outer
function.
• The inner function can use the arguments and variables of the outer
function. The outer function cannot use the arguments and variables of the
inner function.
The following example shows nested functions:
function addSquares (a,b) {
function square(x) {
return x*x
}
return square(a) + square(b)
}
a=addSquares(2,3) // returns 13
b=addSquares(3,4) // returns 25
c=addSquares(4,5) // returns 41
When a function contains a nested function, you can call the outer function and
specify arguments for both the outer and inner function:
Function
82 Core JavaScript Reference
function outside(x) {
function inside(y) {
return x+y
}
return inside
}
result=outside(3)(5) // returns 8
Backward
Compatibility
JavaScript 1.3 and earlier versions. In addition to being available as a local
variable, the arguments array is also a property of the Function object and
can be preceded by the function name, as follows:
functionName.arguments[i]
JavaScript 1.1 and earlier versions. You cannot nest a function statement in
another statement or in itself.
Property
Summary
Method Summary
Property Description
arguments An array corresponding to the arguments passed to a
function.
arguments.callee Specifies the function body of the currently executing
function.
arguments.caller Specifies the name of the function that invoked the currently
executing function.
arguments.length Specifies the number of arguments passed to the function.
arity Specifies the number of arguments expected by the function.
constructor Specifies the function that creates an object’s prototype.
length Specifies the number of arguments expected by the function.
prototype Allows the addition of properties to a Function object.
Method Description
apply Allows you to apply a method of another object in the
context of a different object (the calling object).
call Allows you to call (execute) a method of another object in
the context of a different object (the calling object).
toSource Returns a string representing the source code of the function.
Overrides the Object.toSource method.
Chapter 1, Objects, Methods, and Properties 83
Function.apply
Examples Example 1. The following function returns a string containing the formatted
representation of a number padded with leading zeros.
// This function returns a string padded with leading zeros
function padZeros(num, totalLen) {
var numStr = num.toString() // Initialize return value
// as string
var numZeros = totalLen numStr.length // Calculate no. of zeros
if (numZeros > 0) {
for (var i = 1; i <= numZeros; i++) {
numStr = "0" + numStr
}
}
return numStr
}
The following statements call the padZeros function.
result=padZeros(42,4) // returns "0042"
result=padZeros(42,2) // returns "42"
result=padZeros(5,4) // returns "0005"
apply .
Specifies the name of the function that invoked the currently executing
function.
Description caller is no longer used.
The caller property is available only within the body of a function.
If the currently executing function was invoked by the top level of a JavaScript
program, the value of caller is null.
The this keyword does not refer to the currently executing function, so you
must refer to functions and Function objects by name, even within the
function body.
The caller property is a reference to the calling function, so
• If you use it in a string context, you get the result of calling
functionName.toString. That is, the decompiled canonical source form
of the function.
• You can also call the calling function, if you know what arguments it might
want. Thus, a called function can call its caller without knowing the name
of the particular caller, provided it knows that all of its callers have the same
form and fit, and that they will not call the called function again
unconditionally (which would result in infinite recursion).
Property of Function
Implemented in JavaScript 1.1, NES 2.0
Deprecated in JavaScript 1.3
Chapter 1, Objects, Methods, and Properties 89
Function.arguments.length
Examples The following code checks the value of a function’s caller property.
function myFunc() {
if (arguments.caller == null) {
return ("The function was called from the top!")
} else return ("This function’s caller was " + arguments.caller)
}
See also Function.arguments
arguments.length .
arity .
constructor .
Specifies the function that creates an object’s prototype. Note that the value of
this property is a reference to the function itself, not a string containing the
function’s name.
Description See Object.constructor.
length .
A value from which instances of a particular class are created. Every object that
can be created by calling a constructor function has an associated prototype
property.
Property of Function
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Property of Function
Implemented in JavaScript 1.1
ECMA version ECMA-262
Property of Function
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Chapter 1, Objects, Methods, and Properties 93
Function.prototype
Description You can add new properties or methods to an existing class by adding them to
the prototype associated with the constructor function for that class. The syntax
for adding a new property or method is:
fun.prototype. name = value
where
If you add a property to the prototype for an object, then all objects created
with that object’s constructor function will have that new property, even if the
objects existed before you created the new property. For example, assume you
have the following statements:
var array1 = new Array();
var array2 = new Array(3);
Array.prototype.description=null;
array1.description="Contains some stuff"
array2.description="Contains other stuff"
After you set a property for the prototype, all subsequent objects created with
Array will have the property:
anotherArray=new Array()
anotherArray.description="Currently empty"
Example The following example creates a method, str_rep, and uses the statement
String.prototype.rep = str_rep to add the method to all String objects.
All objects created with new String() then have that method, even objects
already created. The example then creates an alternate method and adds that to
one of the String objects using the statement s1.rep = fake_rep. The
str_rep method of the remaining String objects is not altered.
fun The name of the constructor function object you want to change.
name The name of the property or method to be created.
value The value initially assigned to the new property or method.
Function.toSource
94 Core JavaScript Reference
var s1 = new String("a")
var s2 = new String("b")
var s3 = new String("c")
// Create a repeatstringNtimes method for all String objects
function str_rep(n) {
var s = "", t = this.toString()
while (n >= 0) s += t
return s
}
String.prototype.rep = str_rep
s1a=s1.rep(3) // returns "aaa"
s2a=s2.rep(5) // returns "bbbbb"
s3a=s3.rep(2) // returns "cc"
// Create an alternate method and assign it to only one String variable
function fake_rep(n) {
return "repeat " + this + " " + n + " times."
}
s1.rep = fake_rep
s1b=s1.rep(1) // returns "repeat a 1 times."
s2b=s2.rep(4) // returns "bbbb"
s3b=s3.rep(6) // returns "cccccc"
The function in this example also works on String objects not created with
the String constructor. The following code returns "zzz".
"z".rep(3)
toSource .
java
A top-level object used to access any Java class in the package java.*.
Created by The java object is a top-level, predefined JavaScript object. You can
automatically access it without using a constructor or calling a method.
Description The java object is a convenience synonym for the property Packages.java.
See also Packages, Packages.java
Core object
Implemented in JavaScript 1.1, NES 2.0
JavaArray
98 Core JavaScript Reference
JavaArray
A wrapped Java array accessed from within JavaScript code is a member of the
type JavaArray.
Created by Any Java method which returns an array. In addition, you can create a
JavaArray with an arbitrary data type using the newInstance method of
the Array class:
public static Object newInstance(Class componentType,
int length)
throws NegativeArraySizeException
Description The JavaArray object is an instance of a Java array that is created in or
passed to JavaScript. JavaArray is a wrapper for the instance; all references
to the array instance are made through the JavaArray.
In JavaScript 1.4 and later, the componentType parameter is either a
JavaClass object representing the type of the array or class object, such as
one returned by java.lang.Class.forName. In JavaScript 1.3 and earlier,
componentType must be a class object.
Use zero-based indexes to access the elements in a JavaArray object, just as
you do to access elements in an array in Java. For example:
var javaString = new java.lang.String("Hello world!");
var byteArray = javaString.getBytes();
byteArray[0] // returns 72
byteArray[1] // returns 101
Any Java data brought into JavaScript is converted to JavaScript data types.
When the JavaArray is passed back to Java, the array is unwrapped and can
be used by Java code. See the Core JavaScript Guide for more information
about data type conversions.
In JavaScript 1.4 and later, the methods of java.lang.Object are inherited
by JavaArray.
Core object
Implemented in JavaScript 1.1, NES 2.0
Chapter 1, Objects, Methods, and Properties 99
JavaArray
Backward
compatibility
JavaScript 1.3 and earlier. The methods of java.lang.Object are not
inherited by JavaArray. In addition, the toString method is inherited from
the Object object and returns the following value:
[object JavaArray]
You must specify a class object, such as one returned by
java.lang.Object.forName, for the componentType parameter of
newInstance when you use this method to create an array. You cannot use a
JavaClass object for the componentType parameter.
Property
Summary
Method Summary
In JavaScript 1.4 and later, JavaArray also inherits methods from the Java
array superclass, java.lang.Object.
Examples Example 1. Instantiating a JavaArray in JavaScript.
In this example, the JavaArray byteArray is created by the
java.lang.String.getBytes method, which returns an array.
var javaString = new java.lang.String("Hello world!");
var byteArray = javaString.getBytes();
Property Description
length The number of elements in the Java array represented by
JavaArray.
Method Description
toString In JavaScript 1.4, this method is overridden by the
inherited method java.lang.Object.toString.
In JavaScript 1.3 and earlier, this method returns a
string identifying the object as a JavaArray.
JavaArray.length
100 Core JavaScript Reference
Example 2. Instantiating a JavaArray in JavaScript with the newInstance
method.
In JavaScript 1.4, you can use a JavaClass object as the argument for the
newInstance method which creates the array, as shown in the following
code:
var dogs = java.lang.reflect.Array.newInstance(java.lang.String, 5)
In JavaScript 1.1, use a class object returned by java.lang.Class.forName
as the argument for the newInstance method, as shown in the following
code:
var dataType = java.lang.Class.forName("java.lang.String")
var dogs = java.lang.reflect.Array.newInstance(dataType, 5)
length .
JavaObject
The type of a wrapped Java object accessed from within JavaScript code.
Created by Any Java method which returns an object type. In addition, you can explicitly
construct a JavaObject using the object’s Java constructor with the
Packages keyword:
new Packages. JavaClass( parameterList)
where JavaClass is the fully-specified name of the object’s Java class.
Parameters
Description The JavaObject object is an instance of a Java class that is created in or
passed to JavaScript. JavaObject is a wrapper for the instance; all references
to the class instance are made through the JavaObject.
Any Java data brought into JavaScript is converted to JavaScript data types.
When the JavaObject is passed back to Java, it is unwrapped and can be
used by Java code. See the Core JavaScript Guide for more information about
data type conversions.
Property
Summary
Inherits public data members from the Java class of which it is an instance as
properties. It also inherits public data members from any superclass as
properties.
Method Summary Inherits public methods from the Java class of which it is an instance. The
JavaObject also inherits methods from java.lang.Object and any other
superclass.
Core object
Implemented in JavaScript 1.1, NES 2.0
parameterList An optional list of parameters, specified by the constructor in
the Java class.
Chapter 1, Objects, Methods, and Properties 105
JavaObject
Examples Example 1. Instantiating a Java object in JavaScript.
The following code creates the JavaObject theString, which is an
instance of the class java.lang.String:
var theString = new Packages.java.lang.String("Hello, world")
Because the String class is in the java package, you can also use the java
synonym and omit the Packages keyword when you instantiate the class:
var theString = new java.lang.String("Hello, world")
Example 2. Accessing methods of a Java object.
Because the JavaObject theString is an instance of
java.lang.String, it inherits all the public methods of
java.lang.String. The following example uses the startsWith method
to check whether theString begins with “Hello”.
var theString = new java.lang.String("Hello, world")
theString.startsWith("Hello") // returns true
Example 3. Accessing inherited methods.
Because getClass is a method of Object, and java.lang.String
extends Object, the String class inherits the getClass method.
Consequently, getClass is also a method of the JavaObject which
instantiates String in JavaScript.
var theString = new java.lang.String("Hello, world")
theString.getClass() // returns java.lang.String
See also JavaArray, JavaClass, JavaPackage, Packages
JavaPackage
106 Core JavaScript Reference
JavaPackage
A JavaScript reference to a Java package.
Created by A reference to the package name used with the Packages keyword:
Packages. JavaPackage
where JavaPackage is the name of the object’s Java package. If the package is
in the java, netscape, or sun packages, the Packages keyword is
optional.
Description In Java, a package is a collection of Java classes or other Java packages. For
example, the netscape package contains the package
netscape.javascript; the netscape.javascript package contains the
classes JSObject and JSException.
In JavaScript, a JavaPackage is a reference to a Java package. For example, a
reference to netscape is a JavaPackage. netscape.javascript is both
a JavaPackage and a property of the netscape JavaPackage.
A JavaClass object is a reference to one of the classes in a package, such as
netscape.javascript.JSObject. The JavaPackage and JavaClass
hierarchy reflect the Java package and class hierarchy.
Although the packages and classes contained in a JavaPackage are its
properties, you cannot use a for...in statement to enumerate them as you
can enumerate the properties of other objects.
Property
Summary
The properties of a JavaPackage are the JavaClass objects and any other
JavaPackage objects it contains.
Examples Suppose the Redwood corporation uses the Java redwood package to contain
various Java classes that it implements. The following code creates the
JavaPackage red:
var red = Packages.redwood
See also JavaArray, JavaClass, JavaObject, Packages
Core object
Implemented in JavaScript 1.1, NES 2.0
Chapter 1, Objects, Methods, and Properties 107
Math
Math
A built-in object that has properties and methods for mathematical constants
and functions. For example, the Math object’s PI property has the value of pi.
Created by The Math object is a top-level, predefined JavaScript object. You can
automatically access it without using a constructor or calling a method.
Description All properties and methods of Math are static. You refer to the constant PI as
Math.PI and you call the sine function as Math.sin(x), where x is the
method’s argument. Constants are defined with the full precision of real
numbers in JavaScript.
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)
}
Property
Summary
Core object
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
Property Description
E Euler’s constant and the base of natural logarithms, approximately
2.718.
LN10 Natural logarithm of 10, approximately 2.302.
LN2 Natural logarithm of 2, approximately 0.693.
LOG10E Base 10 logarithm of E (approximately 0.434).
LOG2E Base 2 logarithm of E (approximately 1.442).
PI Ratio of the circumference of a circle to its diameter, approximately
3.14159.
SQRT1_2 Square root of 1/2; equivalently, 1 over the square root of 2,
approximately 0.707.
SQRT2 Square root of 2, approximately 1.414.
Math
108 Core JavaScript Reference
Method Summary
In addition, this object inherits the watch and unwatch methods from
Object.
Method Description
abs Returns the absolute value of a number.
acos Returns the arccosine (in radians) of a number.
asin Returns the arcsine (in radians) of a number.
atan Returns the arctangent (in radians) of a number.
atan2 Returns the arctangent of the quotient of its arguments.
ceil Returns the smallest integer greater than or equal to a number.
cos Returns the cosine of a number.
exp Returns Enumber, where number is the argument, and E is Euler’s
constant, the base of the natural logarithms.
floor Returns the largest integer less than or equal to a number.
log Returns the natural logarithm (base E) of a number.
max Returns the greater of two numbers.
min Returns the lesser of two numbers.
pow Returns base to the exponent power, that is, baseexponent.
random Returns a pseudo-random number between 0 and 1.
round Returns the value of a number rounded to the nearest integer.
sin Returns the sine of a number.
sqrt Returns the square root of a number.
tan Returns the tangent of a number.
Chapter 1, Objects, Methods, and Properties 109
Math.abs
abs .
E .
Returns Ex, where x is the argument, and E is Euler’s constant, the base of the
natural logarithms.
Syntax exp(x)
Parameters
Description Because exp is a static method of Math, you always use it as Math.exp(),
rather than as a method of a Math object you created.
Property of Math
Static, Read-only
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
Method of Math
Static
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
x A number
Chapter 1, Objects, Methods, and Properties 115
Math.floor
Examples The following function returns the exponential value of the variable x:
function getExp(x) {
return Math.exp(x)
}
If you pass getExp the value 1, it returns 2.718281828459045.
See also Math.E, Math.log, Math.pow
floor .
LN10 .
PI .
SQRT1_2 .
The square root of 1/2; equivalently, 1 over the square root of 2, approximately
0.707.
Examples The following function returns 1 over the square root of 2:
function getRoot1_2() {
return Math.SQRT1_2
}
Description Because SQRT1_2 is a static property of Math, you always use it as
Math.SQRT1_2, rather than as a property of a Math object you created.
SQRT2 .
netscape
A top-level object used to access any Java class in the package netscape.*.
Created by The netscape object is a top-level, predefined JavaScript object. You can
automatically access it without using a constructor or calling a method.
Description The netscape object is a convenience synonym for the property
Packages.netscape.
See also Packages, Packages.netscape
Core object
Implemented in JavaScript 1.1, NES 2.0
Chapter 1, Objects, Methods, and Properties 127
Number
Number
Lets you work with numeric values. The Number object is an object wrapper for
primitive numeric values.
Created by The Number constructor:
new Number( value)
Parameters
Description The primary uses for the Number object are:
• To access its constant properties, which represent the largest and smallest
representable numbers, positive and negative infinity, and the Not-a-
Number value.
• To create numeric objects that you can add properties to. Most likely, you
will rarely need to create a Number object.
The properties of Number are properties of the class itself, not of individual
Number objects.
JavaScript 1.2: Number(x) now produces NaN rather than an error if x is a string
that does not contain a well-formed numeric literal. For example,
x=Number("three");
document.write(x + "<BR>");
prints NaN
You can convert any object to a number using the top-level Number function.
Core object
Implemented in JavaScript 1.1, NES 2.0
JavaScript 1.2: modified behavior of Number constructor
JavaScript 1.3: added toSource method
ECMA version ECMA-262
value The numeric value of the object being created.
Number
128 Core JavaScript Reference
Property
Summary
Method Summary
In addition, this object inherits the watch and unwatch methods from
Object.
Examples Example 1. The following example uses the Number object’s properties to
assign values to several numeric variables:
biggestNum = Number.MAX_VALUE
smallestNum = Number.MIN_VALUE
infiniteNum = Number.POSITIVE_INFINITY
negInfiniteNum = Number.NEGATIVE_INFINITY
notANum = Number.NaN
Property Description
constructor Specifies the function that creates an object’s prototype.
MAX_VALUE The largest representable number.
MIN_VALUE The smallest representable number.
NaN Special “not a number” value.
NEGATIVE_INFINITY Special value representing negative infinity; returned on
overflow.
POSITIVE_INFINITY Special value representing infinity; returned on overflow.
prototype Allows the addition of properties to a Number object.
Method Description
toSource Returns an object literal representing the specified Number object;
you can use this value to create a new object. Overrides the
Object.toSource method.
toString Returns a string representing the specified object. Overrides the
Object.toString method.
valueOf Returns the primitive value of the specified object. Overrides the
Object.valueOf method.
Chapter 1, Objects, Methods, and Properties 129
Number.constructor
Example 2. The following example creates a Number object, myNum, then adds
a description property to all Number objects. Then a value is assigned to the
myNum object’s description property.
myNum = new Number(65)
Number.prototype.description=null
myNum.description="wind speed"
constructor .
Specifies the function that creates an object’s prototype. Note that the value of
this property is a reference to the function itself, not a string containing the
function’s name.
Description See Object.constructor.
MAX_VALUE .
MIN_VALUE .
Represents the prototype for this class. You can use the prototype to add
properties or methods to all instances of a class. For information on prototypes,
see Function.prototype.
toSource .
Object
Object is the primitive JavaScript object type. All JavaScript objects are
descended from Object. That is, all JavaScript objects have the methods
defined for Object.
Created by The Object constructor:
new Object()
Parameters None
Property
Summary
Method Summary
Core object
Implemented in JavaScript 1.0: toString method
JavaScript 1.1, NES 2.0: added eval and valueOf methods;
constructor property
JavaScript 1.2: deprecated eval method
JavaScript 1.3: added toSource method
JavaScript 1.4: removed eval method
ECMA version ECMA-262
Property Description
constructor Specifies the function that creates an object’s prototype.
prototype Allows the addition of properties to all objects.
Method Description
eval Deprecated. Evaluates a string of JavaScript code in the context of
the specified object.
toSource Returns an object literal representing the specified object; you can
use this value to create a new object.
toString Returns a string representing the specified object.
unwatch Removes a watchpoint from a property of the object.
Chapter 1, Objects, Methods, and Properties 137
Object.constructor
constructor .
Specifies the function that creates an object’s prototype. Note that the value of
this property is a reference to the function itself, not a string containing the
function’s name.
Description All objects inherit a constructor property from their prototype:
o = new Object // or o = {} in JavaScript 1.2
o.constructor == Object
a = new Array // or a = [] in JavaScript 1.2
a.constructor == Array
n = new Number(3)
n.constructor == Number
Even though you cannot construct most HTML objects, you can do
comparisons. For example,
document.constructor == Document
document.form3.constructor == Form
Examples The following example creates a prototype, Tree, and an object of that type,
theTree. The example then displays the constructor property for the object
theTree.
function Tree(name) {
this.name=name
}
theTree = new Tree("Redwood")
document.writeln("<B>theTree.constructor is</B> " +
theTree.constructor + "<P>")
This example displays the following output:
theTree.constructor is function Tree(name) { this.name = name; }
valueOf Returns the primitive value of the specified object.
watch Adds a watchpoint to a property of the object.
Method Description
Property of Object
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Object.eval
138 Core JavaScript Reference
eval .
Represents the prototype for this class. You can use the prototype to add
properties or methods to all instances of a class. For more information, see
Function.prototype.
Method of Object
Implemented in JavaScript 1.1, NES 2.0
JavaScript 1.2, NES 3.0: deprecated as method of objects; retained as
top-level function
JavaScript 1.4: removed as method of objects
string Any string representing a JavaScript expression, statement, or
sequence of statements. The expression can include variables and
properties of existing objects.
Property of Object
Implemented in JavaScript 1.1
ECMA version ECMA-262
Chapter 1, Objects, Methods, and Properties 139
Object.toSource
toSource .
toString .
Watches for a property to be assigned a value and runs a function when that
occurs.
Syntax watch( prop, handler)
Parameters
Description Watches for assignment to a property named prop in this object, calling
handler(prop, oldval, newval) whenever prop is set and storing the
return value in that property. A watchpoint can filter (or nullify) the value
assignment, by returning a modified newval (or oldval).
If you delete a property for which a watchpoint has been set, that watchpoint
does not disappear. If you later recreate the property, the watchpoint is still in
effect.
To remove a watchpoint, use the unwatch method. By default, the watch
method is inherited by every object descended from Object.
The JavaScript debugger has functionality similar to that provided by this
method, as well as other debugging options. For information on the debugger,
see Getting Started with Netscape JavaScript Debugger.
Method of Object
Implemented in JavaScript 1.2, NES 3.0
prop The name of a property of the object.
handler A function to call.
Object.watch
146 Core JavaScript Reference
Example <script language="JavaScript1.2">
o = {p:1}
o.watch("p",
function (id,oldval,newval) {
document.writeln("o." + id + " changed from "
+ oldval + " to " + newval)
return newval
})
o.p = 2
o.p = 3
delete o.p
o.p = 4
o.unwatch(’p’)
o.p = 5
</script>
This script displays the following:
o.p changed from 1 to 2
o.p changed from 2 to 3
o.p changed from 3 to 4
Chapter 1, Objects, Methods, and Properties 147
Packages
Packages
A top-level object used to access Java classes from within JavaScript code.
Created by The Packages object is a top-level, predefined JavaScript object. You can
automatically access it without using a constructor or calling a method.
Description The Packages object lets you access the public methods and fields of an
arbitrary Java class from within JavaScript. The java, netscape, and sun
properties represent the packages java.*, netscape.*, and sun.* respectively. Use
standard Java dot notation to access the classes, methods, and fields in these
packages. For example, you can access a constructor of the Frame class as
follows:
var theFrame = new Packages.java.awt.Frame();
For convenience, JavaScript provides the top-level netscape, sun, and java
objects that are synonyms for the Packages properties with the same names.
Consequently, you can access Java classes in these packages without the
Packages keyword, as follows:
var theFrame = new java.awt.Frame();
The className property represents the fully qualified path name of any other
Java class that is available to JavaScript. You must use the Packages object to
access classes outside the netscape, sun, and java packages.
Property
Summary
Core object
Implemented in JavaScript 1.1, NES 2.0
Property Description
className The fully qualified name of a Java class in a package other than
netscape, java, or sun that is available to JavaScript.
java Any class in the Java package java.*.
netscape Any class in the Java package netscape.*.
sun Any class in the Java package sun.*.
Packages.className
148 Core JavaScript Reference
Examples The following JavaScript function creates a Java dialog box:
function createWindow() {
var theOwner = new Packages.java.awt.Frame();
var theWindow = new Packages.java.awt.Dialog(theOwner);
theWindow.setSize(350,200);
theWindow.setTitle("Hello, World");
theWindow.setVisible(true);
}
In the previous example, the function instantiates theWindow as a new
Packages object. The setSize, setTitle, and setVisible methods are
all available to JavaScript as public methods of java.awt.Dialog.
className .
The fully qualified name of a Java class in a package other than netscape,
java, or sun that is available to JavaScript.
Syntax Packages. className
where classname is the fully qualified name of a Java class.
Description You must use the className property of the Packages object to access
classes outside the netscape, sun, and java packages.
Examples The following code accesses the constructor of the CorbaObject class in the
myCompany package from JavaScript:
var theObject = new Packages.myCompany.CorbaObject()
In the previous example, the value of the className property is
myCompany.CorbaObject, the fully qualified path name of the
CorbaObject class.
Property of Packages
Implemented in JavaScript 1.1, NES 2.0
Chapter 1, Objects, Methods, and Properties 149
Packages.java
java .
sun .
RegExp
A regular expression object contains the pattern of a regular expression. It has
properties and methods for using that regular expression to find and replace
matches in strings.
In addition to the properties of an individual regular expression object that you
create using the RegExp constructor function, the predefined RegExp object has
static properties that are set whenever any regular expression is used.
Created by A literal text format or the RegExp constructor function.
The literal format is used as follows:
/ pattern/ flags
The constructor function is used as follows:
new RegExp(" pattern"[, " flags"])
Parameters
Notice that the parameters to the literal format do not use quotation marks to
indicate strings, while the parameters to the constructor function do use
quotation marks. So the following expressions create the same regular
expression:
/ab+c/i
new RegExp("ab+c", "i")
Core object
Implemented in JavaScript 1.2, NES 3.0
JavaScript 1.3: added toSource method
pattern The text of the regular expression.
flags If specified, flags can have one of the following values:
• g: global match
• i: ignore case
• gi: both global match and ignore case
RegExp
152 Core JavaScript Reference
Description When using the constructor function, the normal string escape rules (preceding
special characters with \ when included in a string) are necessary. For example,
the following are equivalent:
re = new RegExp("\\w+")
re = /\w+/
The following table provides a complete list and description of the special
characters that can be used in regular expressions.
Table 1.1 Special characters in regular expressions.
Character Meaning
\ For characters that are usually treated literally, indicates that the next
character is special and not to be interpreted literally.
For example, /b/ matches the character ’b’. By placing a backslash in
front of b, that is by using /\b/, the character becomes special to
mean match a word boundary.
-or-
For characters that are usually treated specially, indicates that the next
character is not special and should be interpreted literally.
For example, * is a special character that means 0 or more occurrences
of the preceding character should be matched; for example, /a*/
means match 0 or more a’s. To match * literally, precede the it with a
backslash; for example, /a\*/ matches ’a*’.
^ Matches beginning of input or line.
For example, /^A/ does not match the ’A’ in "an A," but does match it
in "An A."
$ Matches end of input or line.
For example, /t$/ does not match the ’t’ in "eater", but does match it
in "eat"
* Matches the preceding character 0 or more times.
For example, /bo*/ matches ’boooo’ in "A ghost booooed" and ’b’ in
"A bird warbled", but nothing in "A goat grunted".
+ Matches the preceding character 1 or more times. Equivalent to {1,}.
For example, /a+/ matches the ’a’ in "candy" and all the a’s in
"caaaaaaandy."
? Matches the preceding character 0 or 1 time.
For example, /e?le?/ matches the ’el’ in "angel" and the ’le’ in
"angle."
Chapter 1, Objects, Methods, and Properties 153
RegExp
. (The decimal point) matches any single character except the newline
character.
For example, /.n/ matches ’an’ and ’on’ in "nay, an apple is on the
tree", but not ’nay’.
(x) Matches ’x’ and remembers the match.
For example, /(foo)/ matches and remembers ’foo’ in "foo bar." The
matched substring can be recalled from the resulting array’s elements
[1], ..., [n], or from the predefined RegExp object’s properties $1,
..., $9.
x|y Matches either 'x' or 'y'.
For example, /green|red/ matches 'green' in "green apple" and 'red'
in "red apple."
{n} Where n is a positive integer. Matches exactly n occurrences of the
preceding character.
For example, /a{2}/ doesn't match the 'a' in "candy," but it matches
all of the a's in "caandy," and the first two a's in "caaandy."
{n,} Where n is a positive integer. Matches at least n occurrences of the
preceding character.
For example, /a{2,} doesn't match the 'a' in "candy", but matches all
of the a's in "caandy" and in "caaaaaaandy."
{n,m} Where n and m are positive integers. Matches at least n and at most m
occurrences of the preceding character.
For example, /a{1,3}/ matches nothing in "cndy", the 'a' in "candy,"
the first two a's in "caandy," and the first three a's in "caaaaaaandy"
Notice that when matching "caaaaaaandy", the match is "aaa", even
though the original string had more a’s in it.
[xyz] A character set. Matches any one of the enclosed characters. You can
specify a range of characters by using a hyphen.
For example, [abcd] is the same as [ac]. They match the 'b' in
"brisket" and the 'c' in "ache".
[^xyz] A negated or complemented character set. That is, it matches anything
that is not enclosed in the brackets. You can specify a range of
characters by using a hyphen.
For example, [^abc] is the same as [^ac]. They initially match 'r'
in "brisket" and 'h' in "chop."
[\b] Matches a backspace. (Not to be confused with \b.)
Table 1.1 Special characters in regular expressions. (Continued)
Character Meaning
RegExp
154 Core JavaScript Reference
\b Matches a word boundary, such as a space. (Not to be confused with
[\b].)
For example, /\bn\w/ matches the ’no’ in "noonday";/\wy\b/
matches the ’ly’ in "possibly yesterday."
\B Matches a non-word boundary.
For example, /\w\Bn/ matches ’on’ in "noonday", and /y\B\w/
matches ’ye’ in "possibly yesterday."
\c X Where X is a control character. Matches a control character in a string.
For example, /\cM/ matches control-M in a string.
\d Matches a digit character. Equivalent to [09].
For example, /\d/ or /[09]/ matches ’2’ in "B2 is the suite
number."
\D Matches any non-digit character. Equivalent to [^09].
For example, /\D/ or /[^09]/ matches ’B’ in "B2 is the suite
number."
\f Matches a form-feed.
\n Matches a linefeed.
\r Matches a carriage return.
\s Matches a single white space character, including space, tab, form feed,
line feed. Equivalent to [ \f\n\r\t\v].
for example, /\s\w*/ matches ’ bar’ in "foo bar."
\S Matches a single character other than white space. Equivalent to [^
\f\n\r\t\v].
For example, /\S/\w* matches ’foo’ in "foo bar."
\t Matches a tab
\v Matches a vertical tab.
\w Matches any alphanumeric character including the underscore.
Equivalent to [AZaz09_].
For example, /\w/ matches ’a’ in "apple," ’5’ in "$5.28," and ’3’ in "3D."
\W Matches any non-word character. Equivalent to [^AZaz09_].
For example, /\W/ or /[^$AZaz09_]/ matches ’%’ in "50%."
Table 1.1 Special characters in regular expressions. (Continued)
Character Meaning
Chapter 1, Objects, Methods, and Properties 155
RegExp
The literal notation provides compilation of the regular expression when the
expression is evaluated. Use literal notation when the regular expression will
remain constant. For example, if you use literal notation to construct a regular
expression used in a loop, the regular expression won’t be recompiled on each
iteration.
The constructor of the regular expression object, for example,
new RegExp("ab+c"), provides runtime compilation of the regular expression.
Use the constructor function when you know the regular expression pattern
will be changing, or you don’t know the pattern and are getting it from another
source, such as user input. Once you have a defined regular expression, and if
the regular expression is used throughout the script and may change, you can
use the compile method to compile a new regular expression for efficient
reuse.
A separate predefined RegExp object is available in each window; that is, each
separate thread of JavaScript execution gets its own RegExp object. Because
each script runs to completion without interruption in a thread, this assures that
different scripts do not overwrite values of the RegExp object.
The predefined RegExp object contains the static properties input,
multiline, lastMatch, lastParen, leftContext, rightContext,
and $1 through $9. The input and multiline properties can be preset. The
values for the other static properties are set after execution of the exec and
test methods of an individual regular expression object, and after execution
of the match and replace methods of String.
\ n Where n is a positive integer. A back reference to the last substring
matching the n parenthetical in the regular expression (counting left
parentheses).
For example, /apple(,)\sorange\1/ matches ’apple, orange’, in
"apple, orange, cherry, peach." A more complete example follows this
table.
Note: If the number of left parentheses is less than the number
specified in \n, the \n is taken as an octal escape as described in the
next row.
\o octal
\x hex
Where \o octal is an octal escape value or \x hex is a hexadecimal
escape value. Allows you to embed ASCII codes into regular
expressions.
Table 1.1 Special characters in regular expressions. (Continued)
Character Meaning
RegExp
156 Core JavaScript Reference
Property
Summary
Note that several of the RegExp properties have both long and short (Perl-like)
names. Both names always refer to the same value. Perl is the programming
language from which JavaScript modeled its regular expressions.
Property Description
$1, ..., $9 Parenthesized substring matches, if any.
$_ See input.
$* See multiline.
$& See lastMatch.
$+ See lastParen.
$‘ See leftContext.
$’ See rightContext.
constructor Specifies the function that creates an object’s prototype.
global Whether or not to test the regular expression against all possible
matches in a string, or only against the first.
ignoreCase Whether or not to ignore case while attempting a match in a
string.
input The string against which a regular expression is matched.
lastIndex The index at which to start the next match.
lastMatch The last matched characters.
lastParen The last parenthesized substring match, if any.
leftContext The substring preceding the most recent match.
multiline Whether or not to search in strings across multiple lines.
prototype Allows the addition of properties to all objects.
rightContext The substring following the most recent match.
source The text of the pattern.
Chapter 1, Objects, Methods, and Properties 157
RegExp
Method Summary
In addition, this object inherits the watch and unwatch methods from
Object.
Examples Example 1. The following script uses the replace method to switch the words
in the string. For the replacement text, the script uses the values of the $1 and
$2 properties of the global RegExp object. Note that the RegExp object name is
not be prepended to the $ properties when they are passed as the second
argument to the replace method.
<SCRIPT LANGUAGE="JavaScript1.2">
re = /(\w+)\s(\w+)/;
str = "John Smith";
newstr=str.replace(re, "$2, $1");
document.write(newstr)
</SCRIPT>
This displays "Smith, John".
Method Description
compile Compiles a regular expression object.
exec Executes a search for a match in its string parameter.
test Tests for a match in its string parameter.
toSource Returns an object literal representing the specified object; you
can use this value to create a new object. Overrides the
Object.toSource method.
toString Returns a string representing the specified object. Overrides the
Object.toString method.
valueOf Returns the primitive value of the specified object. Overrides
the Object.valueOf method.
RegExp.$1, ..., $9
158 Core JavaScript Reference
Example 2. In the following example, RegExp.input is set by the Change
event. In the getInfo function, the exec method uses the value of
RegExp.input as its argument. Note that RegExp is prepended to the $
properties.
<HTML>
<SCRIPT LANGUAGE="JavaScript1.2">
function getInfo() {
re = /(\w+)\s(\d+)/;
re.exec();
window.alert(RegExp.$1 + ", your age is " + RegExp.$2);
}
</SCRIPT>
Enter your first name and your age, and then press Enter.
<FORM>
<INPUT TYPE:"TEXT" NAME="NameAge" onChange="getInfo(this);">
</FORM>
</HTML>
$1, ..., $9 .
See input.
$* .
See multiline.
$& .
See lastMatch.
$+ .
See lastParen.
$‘ .
See leftContext.
$’ .
See rightContext.
RegExp.compile
160 Core JavaScript Reference
compile .
Specifies the function that creates an object’s prototype. Note that the value of
this property is a reference to the function itself, not a string containing the
function’s name.
Description See Object.constructor.
exec .
Executes the search for a match in a specified string. Returns a result array.
Syntax regexp.exec([ str])
regexp([ str])
Parameters
Description As shown in the syntax description, a regular expression’s exec method can be
called either directly, (with regexp.exec(str)) or indirectly (with
regexp(str)).
If you are executing a match simply to find true or false, use the test
method or the String search method.
If the match succeeds, the exec method returns an array and updates
properties of the regular expression object and the predefined regular
expression object, RegExp. If the match fails, the exec method returns null.
Property of RegExp
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Method of RegExp
Implemented in JavaScript 1.2, NES 3.0
regexp The name of the regular expression. It can be a variable name or a
literal.
str The string against which to match the regular expression. If
omitted, the value of RegExp.input is used.
RegExp.exec
162 Core JavaScript Reference
Consider the following example:
<SCRIPT LANGUAGE="JavaScript1.2">
//Match one d followed by one or more b’s followed by one d
//Remember matched b’s and the following d
//Ignore case
myRe=/d(b+)(d)/ig;
myArray = myRe.exec("cdbBdbsbz");
</SCRIPT>
The following table shows the results for this script:
Object Property/Index Description Example
myArray The contents of myArray ["dbBd", "bB", "d"]
index The 0-based index of the match in the
string
1
input The original string cdbBdbsbz
[0] The last matched characters dbBd
[1], ...[ n] The parenthesized substring matches, if
any. The number of possible
parenthesized substrings is unlimited.
[1] = bB
[2] = d
myRe lastIndex The index at which to start the next
match.
5
ignoreCase Indicates if the "i" flag was used to
ignore case
true
global Indicates if the "g" flag was used for a
global match
true
source The text of the pattern d(b+)(d)
Chapter 1, Objects, Methods, and Properties 163
RegExp.exec
If your regular expression uses the "g" flag, you can use the exec method
multiple times to find successive matches in the same string. When you do so,
the search starts at the substring of str specified by the regular expression’s
lastIndex property. For example, assume you have this script:
<SCRIPT LANGUAGE="JavaScript1.2">
myRe=/ab*/g;
str = "abbcdefabh"
myArray = myRe.exec(str);
document.writeln("Found " + myArray[0] +
". Next match starts at " + myRe.lastIndex)
mySecondArray = myRe.exec(str);
document.writeln("Found " + mySecondArray[0] +
". Next match starts at " + myRe.lastIndex)
</SCRIPT>
This script displays the following text:
Found abb. Next match starts at 3
Found ab. Next match starts at 9
RegExp lastMatch
$&
The last matched characters dbBd
leftContext
$‘
The substring preceding the most recent
match
c
rightContext
$’
The substring following the most recent
match
bsbz
$1, ...$9 The parenthesized substring matches, if
any. The number of possible
parenthesized substrings is unlimited, but
RegExp can only hold the last nine.
$1 = bB
$2 = d
lastParen
$+
The last parenthesized substring match, if
any.
d
Object Property/Index Description Example
RegExp.global
164 Core JavaScript Reference
Examples In the following example, the user enters a name and the script executes a
match against the input. It then cycles through the array to see if other names
match the user’s name.
This script assumes that first names of registered party attendees are preloaded
into the array A, perhaps by gathering them from a party database.
<HTML>
<SCRIPT LANGUAGE="JavaScript1.2">
A = ["Frank", "Emily", "Jane", "Harry", "Nick", "Beth", "Rick",
"Terrence", "Carol", "Ann", "Terry", "Frank", "Alice", "Rick",
"Bill", "Tom", "Fiona", "Jane", "William", "Joan", "Beth"]
function lookup() {
firstName = /\w+/i();
if (!firstName)
window.alert (RegExp.input + " isn’t a name!");
else {
count = 0;
for (i=0; i<A.length; i++)
if (firstName[0].toLowerCase() == A[i].toLowerCase()) count++;
if (count ==1)
midstring = " other has ";
else
midstring = " others have ";
window.alert ("Thanks, " + count + midstring + "the same name!")
}
}
</SCRIPT>
Enter your first name and then press Enter.
<FORM> <INPUT TYPE:"TEXT" NAME="FirstName" onChange="lookup(this);"> </
FORM>
</HTML>
global .
The string against which a regular expression is matched. $_ is another name
for the same property.
Property of RegExp
Read-only
Implemented in JavaScript 1.2, NES 3.0
Property of RegExp
Static
Implemented in JavaScript 1.2, NES 3.0
RegExp.lastIndex
166 Core JavaScript Reference
Description Because input is static, it is not a property of an individual regular expression
object. Instead, you always use it as RegExp.input.
If no string argument is provided to a regular expression’s exec or test
methods, and if RegExp.input has a value, its value is used as the argument to
that method.
The script or the browser can preset the input property. If preset and if no
string argument is explicitly provided, the value of input is used as the string
argument to the exec or test methods of the regular expression object. input
is set by the browser in the following cases:
• When an event handler is called for a TEXT form element, input is set to
the value of the contained text.
• When an event handler is called for a TEXTAREA form element, input is set
to the value of the contained text. Note that multiline is also set to true
so that the match can be executed over the multiple lines of text.
• When an event handler is called for a SELECT form element, input is set to
the value of the selected text.
• When an event handler is called for a Link object, input is set to the value
of the text between <A HREF=...> and </A>.
The value of the input property is cleared after the event handler completes.
lastIndex .
A read/write integer property that specifies the index at which to start the next
match.
Property of RegExp
Implemented in JavaScript 1.2, NES 3.0
Chapter 1, Objects, Methods, and Properties 167
RegExp.lastMatch
Description lastIndex is a property of an individual regular expression object.
This property is set only if the regular expression used the "g" flag to indicate
a global search. The following rules apply:
• If lastIndex is greater than the length of the string, regexp.test and
regexp.exec fail, and lastIndex is set to 0.
• If lastIndex is equal to the length of the string and if the regular
expression matches the empty string, then the regular expression matches
input starting at lastIndex.
• If lastIndex is equal to the length of the string and if the regular
expression does not match the empty string, then the regular expression
mismatches input, and lastIndex is reset to 0.
• Otherwise, lastIndex is set to the next position following the most recent
match.
For example, consider the following sequence of statements:
lastMatch .
The last matched characters. $& is another name for the same property.
Description Because lastMatch is static, it is not a property of an individual regular
expression object. Instead, you always use it as RegExp.lastMatch.
re = /(hi)?/
g
Matches the empty string.
re("hi") Returns ["hi", "hi"] with lastIndex equal to 2.
re("hi") Returns [""], an empty array whose zeroth element is the match
string. In this case, the empty string because lastIndex was 2
(and still is 2) and "hi" has length 2.
Property of RegExp
Static, Read-only
Implemented in JavaScript 1.2, NES 3.0
RegExp.lastParen
168 Core JavaScript Reference
lastParen .
The last parenthesized substring match, if any. $+ is another name for the same
property.
Description Because lastParen is static, it is not a property of an individual regular
expression object. Instead, you always use it as RegExp.lastParen.
leftContext .
The substring preceding the most recent match. $‘ is another name for the
same property.
Description Because leftContext is static, it is not a property of an individual regular
expression object. Instead, you always use it as RegExp.leftContext.
multiline .
Represents the prototype for this class. You can use the prototype to add
properties or methods to all instances of a class. For information on prototypes,
see Function.prototype.
rightContext .
The substring following the most recent match. $’ is another name for the
same property.
Description Because rightContext is static, it is not a property of an individual regular
expression object. Instead, you always use it as RegExp.rightContext.
Property of RegExp
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Property of RegExp
Static, Read-only
Implemented in JavaScript 1.2, NES 3.0
RegExp.source
170 Core JavaScript Reference
source .
A read-only property that contains the text of the pattern, excluding the forward
slashes and "g" or "i" flags.
Description source is a property of an individual regular expression object.
You cannot change this property directly. However, calling the compile
method changes the value of this property.
test .
Executes the search for a match between a regular expression and a specified
string. Returns true or false.
Syntax regexp.test([ str])
Parameters
Description When you want to know whether a pattern is found in a string use the test
method (similar to the String.search method); for more information (but
slower execution) use the exec method (similar to the String.match
method).
Property of RegExp
Read-only
Implemented in JavaScript 1.2, NES 3.0
Method of RegExp
Implemented in JavaScript 1.2, NES 3.0
regexp The name of the regular expression. It can be a variable name or a literal.
str The string against which to match the regular expression. If omitted, the
value of RegExp.input is used.
Chapter 1, Objects, Methods, and Properties 171
RegExp.toSource
Example The following example prints a message which depends on the success of the
test:
function testinput(re, str){
if (re.test(str))
midstring = " contains ";
else
midstring = " does not contain ";
document.write (str + midstring + re.source);
}
toSource .
String
An object representing a series of characters in a string.
Created by The String constructor:
new String( string)
Parameters
Description The String object is a wrapper around the string primitive data type. Do not
confuse a string literal with the String object. For example, the following
code creates the string literal s1 and also the String object s2:
s1 = "foo" //creates a string literal value
s2 = new String("foo") //creates a String object
You can call any of the methods of the String object on a string literal
value—JavaScript automatically converts the string literal to a temporary
String object, calls the method, then discards the temporary String object.
You can also use the String.length property with a string literal.
Core object
Implemented in JavaScript 1.0: Create a String object only by quoting characters.
JavaScript 1.1, NES 2.0: added String constructor; added
prototype property; added split method; added ability to pass
strings among scripts in different windows or frames (in previous
releases, you had to add an empty string to another window’s string
to refer to it)
JavaScript 1.2, NES 3.0: added concat, match, replace,
search, slice, and substr methods.
JavaScript 1.3: added toSource method
ECMA version ECMA-262
string Any string.
String
174 Core JavaScript Reference
You should use string literals unless you specifically need to use a String
object, because String objects can have counterintuitive behavior. For
example:
s1 = "2 + 2" //creates a string literal value
s2 = new String("2 + 2")//creates a String object
eval(s1) //returns the number 4
eval(s2) //returns the string "2 + 2"
A string can be represented as a literal enclosed by single or double quotation
marks; for example, “Netscape” or ‘Netscape’.
You can convert the value of any object into a string using the top-level
String function.
Property
Summary
Method Summary
Property Description
constructor Specifies the function that creates an object’s prototype.
length Reflects the length of the string.
prototype Allows the addition of properties to a String object.
Method Description
anchor Creates an HTML anchor that is used as a hypertext target.
big Causes a string to be displayed in a big font as if it were in a
BIG tag.
blink Causes a string to blink as if it were in a BLINK tag.
bold Causes a string to be displayed as if it were in a B tag.
charAt Returns the character at the specified index.
charCodeAt Returns a number indicating the Unicode value of the character
at the given index.
concat Combines the text of two strings and returns a new string.
fixed Causes a string to be displayed in fixed-pitch font as if it were in
a TT tag.
fontcolor Causes a string to be displayed in the specified color as if it
were in a <FONT COLOR=color> tag.
Chapter 1, Objects, Methods, and Properties 175
String
fontsize Causes a string to be displayed in the specified font size as if it
were in a <FONT SIZE=size> tag.
fromCharCode Returns a string created by using the specified sequence of
Unicode values.
indexOf Returns the index within the calling String object of the first
occurrence of the specified value, or -1 if not found.
italics Causes a string to be italic, as if it were in an I tag.
lastIndexOf Returns the index within the calling String object of the last
occurrence of the specified value, or -1 if not found.
link Creates an HTML hypertext link that requests another URL.
match Used to match a regular expression against a string.
replace Used to find a match between a regular expression and a string,
and to replace the matched substring with a new substring.
search Executes the search for a match between a regular expression
and a specified string.
slice Extracts a section of a string and returns a new string.
small Causes a string to be displayed in a small font, as if it were in a
SMALL tag.
split Splits a String object into an array of strings by separating the
string into substrings.
strike Causes a string to be displayed as struck-out text, as if it were in
a STRIKE tag.
sub Causes a string to be displayed as a subscript, as if it were in a
SUB tag.
substr Returns the characters in a string beginning at the specified
location through the specified number of characters.
substring Returns the characters in a string between two indexes into the
string.
sup Causes a string to be displayed as a superscript, as if it were in a
SUP tag.
toLowerCase Returns the calling string value converted to lowercase.
Method Description
String
176 Core JavaScript Reference
In addition, this object inherits the watch and unwatch methods from
Object.
Examples Example 1: String literal. The following statement creates a string literal:
var last_name = "Schaefer"
Example 2: String literal properties. The following statements evaluate to 8,
"SCHAEFER," and "schaefer":
last_name.length
last_name.toUpperCase()
last_name.toLowerCase()
Example 3: Accessing individual characters in a string. You can think of a
string as an array of characters. In this way, you can access the individual
characters in the string by indexing that array. For example, the following code
displays “The first character in the string is H”:
var myString = "Hello"
myString[0] //returns "H"
toSource Returns an object literal representing the specified object; you
can use this value to create a new object. Overrides the
Object.toSource method.
toString Returns a string representing the specified object. Overrides the
Object.toString method.
toUpperCase Returns the calling string value converted to uppercase.
valueOf Returns the primitive value of the specified object. Overrides the
Object.valueOf method.
Method Description
Chapter 1, Objects, Methods, and Properties 177
String.anchor
Example 4: Pass a string among scripts in different windows or frames.
The following code creates two string variables and opens a second window:
var lastName = "Schaefer"
var firstName = "Jesse"
empWindow=window.open(’string2.html’,’window1’,’width=300,height=300’)
If the HTML source for the second window (string2.html) creates two string
variables, empLastName and empFirstName, the following code in the first
window assigns values to the second window’s variables:
empWindow.empFirstName=firstName
empWindow.empLastName=lastName
The following code in the first window displays the values of the second
window’s variables:
alert(’empFirstName in empWindow is ’ + empWindow.empFirstName)
alert(’empLastName in empWindow is ’ + empWindow.empLastName)
anchor .
Returns a number indicating the Unicode value of the character at the given
index.
Syntax charCodeAt([ index])
Parameters
Description Unicode values range from 0 to 65,535. The first 128 Unicode values are a
direct match of the ASCII character set. For information on Unicode, see the
Core JavaScript Guide.
Method of String
Implemented in JavaScript 1.2, NES 3.0
JavaScript 1.3: returns a Unicode value rather than an ISO-Latin-1
value
ECMA version ECMA-262
index An integer between 0 and 1 less than the length of the string. The
default value is 0.
String.concat
182 Core JavaScript Reference
Backward
Compatibility
JavaScript 1.2. The charCodeAt method returns a number indicating the
ISO-Latin-1 codeset value of the character at the given index. The ISO-Latin-1
codeset ranges from 0 to 255. The first 0 to 127 are a direct match of the ASCII
character set.
Example The following example returns 65, the Unicode value for A.
"ABC".charCodeAt(0) // returns 65
concat .
Combines the text of two or more strings and returns a new string.
Syntax concat( string2, string3[, ..., stringN])
Parameters
Description concat combines the text from two strings and returns a new string. Changes
to the text in one string do not affect the other string.
Example The following example combines two strings into a new string.
s1="Oh "
s2="what a beautiful "
s3="mornin’."
s4=s1.concat(s2,s3) // returns "Oh what a beautiful mornin’."
constructor .
Specifies the function that creates an object’s prototype. Note that the value of
this property is a reference to the function itself, not a string containing the
function’s name.
Description See Object.constructor.
Method of String
Implemented in JavaScript 1.2, NES 3.0
string2...
string N
Strings to concatenate to this string.
Property of String
Implemented in JavaScript 1.1, NES 2.0
ECMA version ECMA-262
Chapter 1, Objects, Methods, and Properties 183
String.fixed
fixed .
fromCharCode .
Returns the index within the calling String object of the first occurrence of the
specified value, starting the search at fromIndex, or -1 if the value is not found.
Syntax indexOf( searchValue[, fromIndex])
Method of String
Static
Implemented in JavaScript 1.2, NES 3.0
JavaScript 1.3: uses a Unicode value rather than an ISO-Latin-1
value
ECMA version ECMA-262
num1, ..., num N A sequence of numbers that are Unicode values.
Method of String
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
Chapter 1, Objects, Methods, and Properties 187
String.indexOf
Parameters
Description Characters in a string are indexed from left to right. The index of the first
character is 0, and the index of the last character of a string called stringName
is stringName.length 1.
"Blue Whale".indexOf("Blue") // returns 0
"Blue Whale".indexOf("Blute") // returns 1
"Blue Whale".indexOf("Whale",0) // returns 5
"Blue Whale".indexOf("Whale",5) // returns 5
"Blue Whale".indexOf("",9) // returns 9
"Blue Whale".indexOf("",10) // returns 10
"Blue Whale".indexOf("",11) // returns 10
The indexOf method is case sensitive. For example, the following expression
returns -1:
"Blue Whale".indexOf("blue")
Examples Example 1. The following example uses indexOf and lastIndexOf to locate
values in the string "Brave new world."
var anyString="Brave new world"
//Displays 8
document.write("<P>The index of the first w from the beginning is " +
anyString.indexOf("w"))
//Displays 10
document.write("<P>The index of the first w from the end is " +
anyString.lastIndexOf("w"))
//Displays 6
document.write("<P>The index of ’new’ from the beginning is " +
anyString.indexOf("new"))
//Displays 6
document.write("<P>The index of ’new’ from the end is " +
anyString.lastIndexOf("new"))
searchValue A string representing the value to search for.
fromIndex The location within the calling string to start the search from. It can
be any integer between 0 and the length of the string. The default
value is 0.
String.italics
188 Core JavaScript Reference
Example 2. The following example defines two string variables. The variables
contain the same string except that the second string contains uppercase letters.
The first writeln method displays 19. But because the indexOf method is
case sensitive, the string "cheddar" is not found in myCapString, so the
second writeln method displays -1.
myString="brie, pepper jack, cheddar"
myCapString="Brie, Pepper Jack, Cheddar"
document.writeln(’myString.indexOf("cheddar") is ’ +
myString.indexOf("cheddar"))
document.writeln(’<P>myCapString.indexOf("cheddar") is ’ +
myCapString.indexOf("cheddar"))
Example 3. The following example sets count to the number of occurrences
of the letter x in the string str:
count = 0;
pos = str.indexOf("x");
while ( pos != 1 ) {
count++;
pos = str.indexOf("x",pos+1);
}
See also String.charAt, String.lastIndexOf, String.split
italics .
Returns the index within the calling String object of the last occurrence of the
specified value, or -1 if not found. The calling string is searched backward,
starting at fromIndex.
Syntax lastIndexOf( searchValue[, fromIndex])
Parameters
Method of String
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
searchValue A string representing the value to search for.
fromIndex The location within the calling string to start the search from. It can
be any integer between 0 and the length of the string. The default
value is the length of the string.
String.length
190 Core JavaScript Reference
Description Characters in a string are indexed from left to right. The index of the first
character is 0, and the index of the last character is stringName.length - 1.
"canal".lastIndexOf("a") // returns 3
"canal".lastIndexOf("a",2) // returns 1
"canal".lastIndexOf("a",0) // returns 1
"canal".lastIndexOf("x") // returns 1
The lastIndexOf method is case sensitive. For example, the following
expression returns -1:
"Blue Whale, Killer Whale".lastIndexOf("blue")
Examples The following example uses indexOf and lastIndexOf to locate values in the
string "Brave new world."
var anyString="Brave new world"
//Displays 8
document.write("<P>The index of the first w from the beginning is " +
anyString.indexOf("w"))
//Displays 10
document.write("<P>The index of the first w from the end is " +
anyString.lastIndexOf("w"))
//Displays 6
document.write("<P>The index of ’new’ from the beginning is " +
anyString.indexOf("new"))
//Displays 6
document.write("<P>The index of ’new’ from the end is " +
anyString.lastIndexOf("new"))
See also String.charAt, String.indexOf, String.split
length .
Represents the prototype for this class. You can use the prototype to add
properties or methods to all instances of a class. For information on prototypes,
see Function.prototype.
replace .
Finds a match between a regular expression and a string, and replaces the
matched substring with a new substring.
Syntax replace( regexp, newSubStr)
replace( regexp, function)
Versions prior to JavaScript 1.3:
replace( regexp, newSubStr)
Parameters
Description This method does not change the String object it is called on; it simply returns
a new string.
If you want to execute a global search and replace, or a case insensitive search,
include the g (for global) and i (for ignore case) flags in the regular expression.
These can be included separately or together. The following two examples
below show how to use these flags with replace.
Property of String
Implemented in JavaScript 1.1, NES 3.0
ECMA version ECMA-262
Method of String
Implemented in JavaScript 1.2
regexp The name of the regular expression. It can be a variable name or a literal.
newSubStr The string to put in place of the string found with regexp. This string can
include the RegExp properties $1, ..., $9, lastMatch,
lastParen, leftContext, and rightContext.
function A function to be invoked after the match has been performed.
String.replace
194 Core JavaScript Reference
Specifying a function as a parameter. When you specify a function as the
second parameter, the function is invoked after the match has been performed.
(The use of a function in this manner is often called a lambda expression.)
In your function, you can dynamically generate the string that replaces the
matched substring. The result of the function call is used as the replacement
value.
The nested function can use the matched substrings to determine the new
string (newSubStr) that replaces the found substring. You get the matched
substrings through the parameters of your function. The first parameter of your
function holds the complete matched substring. Other parameters can be used
for parenthetical matches, remembered submatch strings. For example, the
following replace method returns XX.zzzz - XX , zzzz.
"XXzzzz".replace(/(X*)(z*)/,
function (str, p1, p2) {
return str + " " + p1 + " , " + p2;
}
)
The array returned from the exec method of the RegExp object and the
subsequent match is available to your function. You can use the content of the
array plus the input and the index (index of match in the input string)
properties of the array to perform additional tasks before the method replaces
the substring.
Examples Example 1. In the following example, the regular expression includes the
global and ignore case flags which permits replace to replace each occurrence
of ’apples’ in the string with ’oranges.’
<SCRIPT>
re = /apples/gi;
str = "Apples are round, and apples are juicy.";
newstr=str.replace(re, "oranges");
document.write(newstr)
</SCRIPT>
This prints "oranges are round, and oranges are juicy."
Chapter 1, Objects, Methods, and Properties 195
String.replace
Example 2. In the following example, the regular expression is defined in
replace and includes the ignore case flag.
<SCRIPT>
str = "Twas the night before Xmas...";
newstr=str.replace(/xmas/i, "Christmas");
document.write(newstr)
</SCRIPT>
This prints "Twas the night before Christmas..."
Example 3. The following script switches the words in the string. For the
replacement text, the script uses the values of the $1 and $2 properties.
<SCRIPT LANGUAGE="JavaScript1.2">
re = /(\w+)\s(\w+)/;
str = "John Smith";
newstr = str.replace(re, "$2, $1");
document.write(newstr)
</SCRIPT>
This prints "Smith, John".
Example 4. The following example replaces a Fahrenheit degree with its
equivalent Celsius degree. The Fahrenheit degree should be a number ending
with F. The function returns the Celsius number ending with C. For example, if
the input number is 212F, the function returns 100C. If the number is 0F, the
function returns -17.77777777777778C.
The regular expression test checks for any number that ends with F. The
number of Fahrenheit degree is accessible to your function through the
parameter $1. The function sets the Celsius number based on the Fahrenheit
degree passed in a string to the f2c function. f2c then returns the Celsius
number. This function approximates Perl’s s///e flag.
function f2c(x) {
var s = String(x)
var test = /(\d+(\.\d*)?)F\b/g
return s.replace
(test,
myfunction ($0,$1,$2) {
return (($132) * 5/9) + "C";
}
)
}
String.search
196 Core JavaScript Reference
search .
Executes the search for a match between a regular expression and this String
object.
Syntax search( regexp)
Parameters
Description If successful, search returns the index of the regular expression inside the
string. Otherwise, it returns -1.
When you want to know whether a pattern is found in a string use search
(similar to the regular expression test method); for more information (but
slower execution) use match (similar to the regular expression exec method).
Example The following example prints a message which depends on the success of the
test.
function testinput(re, str){
if (str.search(re) != 1)
midstring = " contains ";
else
midstring = " does not contain ";
document.write (str + midstring + re.source);
}
slice .
toString .
sun
A top-level object used to access any Java class in the package sun.*.
Created by The sun object is a top-level, predefined JavaScript object. You can
automatically access it without using a constructor or calling a method.
Description The sun object is a convenience synonym for the property Packages.sun.
See also Packages, Packages.sun
Core object
Implemented in JavaScript 1.1, NES 2.0
Chapter 2, Top-Level Properties and Functions 211
Ch a p t e r
This chapter contains all JavaScript properties and functions not associated with
any object. In the ECMA specification, these properties and functions are
referred to as properties and methods of the global object.
The following table summarizes the top-level properties.
The following table summarizes the top-level functions.
Table 2.1 Top-level properties
Property Description
Infinity A numeric value representing infinity.
NaN A value representing Not-A-Number.
undefined The value undefined.
Table 2.2 Top-level functions
Function Description
escape Returns the hexadecimal encoding of an argument
in the ISO Latin-1 character set; used to create
strings to add to a URL.
eval Evaluates a string of JavaScript code without
reference to a particular object.
escape
212 Core JavaScript Reference
escape
Returns the hexadecimal encoding of an argument in the ISO-Latin-1 character
set.
Syntax escape(" string")
Parameters
Description escape is a top-level function and is not associated with any object.
Use the escape and unescape functions to encode and decode (add property
values manually) a Uniform Resource Locator (URL), a Uniform Resource
Identifier (URI), or a URI-type string.
isFinite Evaluates an argument to determine whether it is a
finite number.
isNaN Evaluates an argument to determine if it is not a
number.
Number Converts an object to a number.
parseFloat Parses a string argument and returns a floating-point
number.
parseInt Parses a string argument and returns an integer.
String Converts an object to a string.
unescape Returns the ASCII string for the specified
hexadecimal encoding value.
Table 2.2 Top-level functions
Function Description
Core function
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262 compatible, except for Unicode characters.
string A string in the ISO-Latin-1 character set.
Chapter 2, Top-Level Properties and Functions 213
escape
The escape function encodes special characters in the specified string and
returns the new string. It encodes spaces, punctuation, and any other character
that is not an ASCII alphanumeric character, with the exception of these
characters:
* @ _ + . /
Unicode. The escape and unescape functions do not use Unicode as
specified by the ECMA specification. Instead, they use the Internet Engineering
Task Force (IETF) guidelines for escaping characters. Within a URI, characters
use US-ASCII characters (ISO-Latin-1 character set). A URI is a sequence of
characters from the basic Latin alphabet, digits, and a few special characters (for
example, / and @). The escape sequences do not support \uXXXX as in
Unicode or %uXXXX as specified by ECMA, but %XX, where XX is a 2-digit
hexadecimal number (for example, %7E). In URI, characters are represented in
octets, as 8-bit bytes.
To allow the escape and unescape functions to work with Web serversupported
URLs and URIs, JavaScript does not use Unicode for these functions.
• escape returns the hexadecimal encoding of the specified string in the
ISO-Latin-1 character set.
• unescape returns the ASCII string, an ISO-Latin-1 character set sequence.
Unicode-specific escape sequences, %uXXXX, are not supported.
Examples Example 1. The following example returns "%26":
escape("&") // returns "%26"
Example 2. The following statement returns a string with encoded characters
for spaces, commas, and apostrophes.
// returns "The_rain.%20In%20Spain%2C%20Ma%92am"
escape("The_rain. In Spain, Ma’am")
See also unescape
eval
214 Core JavaScript Reference
eval
Evaluates a string of JavaScript code without reference to a particular object.
Syntax eval( string)
Parameters
Description eval is a top-level function and is not associated with any object.
The argument of the eval function is a string. If the string represents an
expression, eval evaluates the expression. If the argument represents one or
more JavaScript statements, eval performs the statements. Do not call eval to
evaluate an arithmetic expression; JavaScript evaluates arithmetic expressions
automatically.
If you construct an arithmetic expression as a string, you can use eval to
evaluate it at a later time. For example, suppose you have a variable x. You can
postpone evaluation of an expression involving x by assigning the string value
of the expression, say "3 * x + 2", to a variable, and then calling eval at a
later point in your script.
If the argument of eval is not a string, eval returns the argument unchanged.
In the following example, the String constructor is specified, and eval
returns a String object rather than evaluating the string.
eval(new String("2+2”)) // returns a String object containing "2+2"
eval("2+2”) // returns 4
Core function
Implemented in JavaScript 1.0
JavaScript 1.4: eval cannot be called indirectly
ECMA version ECMA-262
string A string representing a JavaScript expression, statement, or
sequence of statements. The expression can include variables and
properties of existing objects.
Chapter 2, Top-Level Properties and Functions 215
eval
You cannot indirectly use the eval function by invoking it via a name other
than eval; if you do, a runtime error might occur. For example, you should
not use the following code:
var x = 2
var y = 4
var myEval = eval
myEval("x + y")
Backward
Compatibility
JavaScript 1.3 and earlier versions. You can use eval indirectly, although it
is discouraged.
JavaScript 1.1. eval is also a method of all objects. This method is described
for the Object class.
Examples The following examples display output using document.write. In server-side
JavaScript, you can display the same output by calling the write function
instead of using document.write.
Example 1. In the following code, both of the statements containing eval
return 42. The first evaluates the string "x + y + 1"; the second evaluates the
string "42".
var x = 2
var y = 39
var z = "42"
eval("x + y + 1") // returns 42
eval(z) // returns 42
Example 2. In the following example, the getFieldName(n) function returns
the name of the specified form element as a string. The first statement assigns
the string value of the third form element to the variable field. The second
statement uses eval to display the value of the form element.
var field = getFieldName(3)
document.write("The field named ", field, " has value of ",
eval(field + ".value"))
Example 3. The following example uses eval to evaluate the string str. This
string consists of JavaScript statements that open an Alert dialog box and assign
z a value of 42 if x is five, and assigns 0 to z otherwise. When the second
statement is executed, eval will cause these statements to be performed, and it
will also evaluate the set of statements and return the value that is assigned to
z.
var str = "if (x == 5) {alert(’z is 42’); z = 42;} else z = 0; "
document.write("<P>z is ", eval(str))
Infinity
216 Core JavaScript Reference
Example 4. In the following example, the setValue function uses eval to
assign the value of the variable newValue to the text field textObject:
function setValue (textObject, newValue) {
eval ("document.forms[0]." + textObject + ".value") = newValue
}
Example 5. The following example creates breed as a property of the object
myDog, and also as a variable. The first write statement uses eval(’breed’)
without specifying an object; the string "breed" is evaluated without regard to
any object, and the write method displays "Shepherd", which is the value of
the breed variable. The second write statement uses myDog.eval(’breed’)
which specifies the object myDog; the string "breed" is evaluated with regard
to the myDog object, and the write method displays "Lab", which is the value
of the breed property of the myDog object.
function Dog(name,breed,color) {
this.name=name
this.breed=breed
this.color=color
}
myDog = new Dog("Gabby")
myDog.breed="Lab"
var breed=’Shepherd’
document.write("<P>" + eval(’breed’))
document.write("<BR>" + myDog.eval(’breed’))
See also Object.eval method
Infinity
A numeric value representing infinity.
Syntax Infinity
Core property
Implemented in JavaScript 1.3 (In previous versions, Infinity was defined only as
a property of the Number object)
ECMA version ECMA-262
Chapter 2, Top-Level Properties and Functions 217
isFinite
Description Infinity is a top-level property and is not associated with any object.
The initial value of Infinity is Number.POSITIVE_INFINITY. The value
Infinity (positive infinity) is greater than any other number including itself.
This value behaves mathematically like infinity; for example, anything
multiplied by Infinity is Infinity, and anything divided by Infinity is
0.
See also Number.NEGATIVE_INFINITY,Number.POSITIVE_INFINITY
isFinite
Evaluates an argument to determine whether it is a finite number.
Syntax isFinite( number)
Parameters
Description isFinite is a top-level function and is not associated with any object.
You can use this method to determine whether a number is a finite number.
The isFinite method examines the number in its argument. If the argument
is NaN, positive infinity or negative infinity, this method returns false,
otherwise it returns true.
Examples You can check a client input to determine whether it is a finite number.
if(isFinite(ClientInput) == true)
{
/* take specific steps */
}
See also Number.NEGATIVE_INFINITY,Number.POSITIVE_INFINITY
Core function
Implemented in JavaScript 1.3
ECMA version ECMA-262
number The number to evaluate.
isNaN
218 Core JavaScript Reference
isNaN
Evaluates an argument to determine if it is not a number.
Syntax isNaN( testValue)
Parameters
Description isNaN is a top-level function and is not associated with any object.
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.
Examples The following example evaluates floatValue to determine if it is a number
and then calls a procedure accordingly:
floatValue=parseFloat(toFloat)
if (isNaN(floatValue)) {
notFloat()
} else {
isFloat()
}
See also Number.NaN, parseFloat, parseInt
NaN
A value representing Not-A-Number.
Core function
Implemented in JavaScript 1.0: Unix only
JavaScript 1.1, NES 2.0: all platforms
ECMA version ECMA-262
testValue The value you want to evaluate.
Core property
Implemented in JavaScript 1.3 (In previous versions, NaN was defined only as a
property of the Number object)
ECMA version ECMA-262
Chapter 2, Top-Level Properties and Functions 219
Number
Syntax NaN
Description NaN is a top-level property and is not associated with any object.
The initial value of NaN is NaN.
NaN is always unequal to any other number, including NaN itself; you cannot
check for the not-a-number value by comparing to Number.NaN. Use the
isNaN function instead.
Several JavaScript methods (such as the Number constructor, parseFloat,
and parseInt) return NaN if the value specified in the parameter is not a
number.
You might use the NaN property to indicate an error condition for a function
that should return a valid number.
See also isNaN, Number.NaN
Number
Converts the specified object to a number.
Syntax Number( obj)
Parameter
Description Number is a top-level function and is not associated with any object.
When the object is a Date object, Number returns a value in milliseconds
measured from 01 January, 1970 UTC (GMT), positive after this date, negative
before.
If obj is a string that does not contain a well-formed numeric literal, Number
returns NaN.
Core function
Implemented in JavaScript 1.2, NES 3.0
ECMA version ECMA-262
obj An object
parseFloat
220 Core JavaScript Reference
Example The following example converts the Date object to a numerical value:
d = new Date ("December 17, 1995 03:24:00")
alert (Number(d))
This displays a dialog box containing "819199440000."
See also Number
parseFloat
Parses a string argument and returns a floating point number.
Syntax parseFloat( string)
Parameters
Description parseFloat is a top-level function and is not associated with any object.
parseFloat parses its argument, a string, and returns a floating point number.
If it encounters a character other than a sign (+ or -), numeral (0-9), a decimal
point, or an exponent, it returns the value up to that point and ignores that
character and all succeeding characters. Leading and trailing spaces are
allowed.
If the first character cannot be converted to a number, parseFloat returns NaN.
For arithmetic purposes, the NaN value is not a number in any radix. You can
call the isNaN function to determine if the result of parseFloat is NaN. If NaN
is passed on to arithmetic operations, the operation results will also be NaN.
Core function
Implemented in JavaScript 1.0: If the first character of the string specified in
parseFloat(string) cannot be converted to a number, returns NaN
on Solaris and Irix and 0 on all other platforms.
JavaScript 1.1, NES 2.0: Returns NaN on all platforms if the first
character of the string specified in parseFloat(string) cannot be
converted to a number.
ECMA version ECMA-262
string A string that represents the value you want to parse.
Chapter 2, Top-Level Properties and Functions 221
parseInt
Examples The following examples all return 3.14:
parseFloat("3.14")
parseFloat("314e2")
parseFloat("0.0314E+2")
var x = "3.14"
parseFloat(x)
The following example returns NaN:
parseFloat("FF2")
See also isNaN, parseInt
parseInt
Parses a string argument and returns an integer of the specified radix or base.
Syntax parseInt( string[, radix])
Parameters
Description parseInt is a top-level function and is not associated with any object.
The parseInt function parses its first argument, a string, and attempts to return
an integer of the specified radix (base). For example, a radix of 10 indicates to
convert to a decimal number, 8 octal, 16 hexadecimal, and so on. For radixes
above 10, the letters of the alphabet indicate numerals greater than 9. For
example, for hexadecimal numbers (base 16), A through F are used.
Core function
Implemented in JavaScript 1.0: If the first character of the string specified in
parseInt(string) cannot be converted to a number, returns NaN
on Solaris and Irix and 0 on all other platforms.
JavaScript 1.1, LiveWire 2.0: Returns NaN on all platforms if the first
character of the string specified in parseInt(string) cannot be
converted to a number.
ECMA version ECMA-262
string A string that represents the value you want to parse.
radix An integer that represents the radix of the return value.
parseInt
222 Core JavaScript Reference
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. parseInt truncates numbers to integer values. Leading and
trailing spaces are allowed.
If the radix is not specified or is specified as 0, JavaScript assumes the
following:
• If the input string begins with "0x", the radix is 16 (hexadecimal).
• If the input string begins with "0", the radix is eight (octal).
• If the input string begins with any other value, the radix is 10 (decimal).
If the first character cannot be converted to a number, parseInt returns NaN.
For arithmetic purposes, the NaN value is not a number in any radix. You can
call the isNaN function to determine if the result of parseInt is NaN. If NaN is
passed on to arithmetic operations, the operation results will also be NaN.
Examples The following examples all return 15:
parseInt("F", 16)
parseInt("17", 8)
parseInt("15", 10)
parseInt(15.99, 10)
parseInt("FXX123", 16)
parseInt("1111", 2)
parseInt("15*3", 10)
The following examples all return NaN:
parseInt("Hello", 8)
parseInt("0x7", 10)
parseInt("FFF", 10)
Even though the radix is specified differently, the following examples all return
17 because the input string begins with "0x".
parseInt("0x11", 16)
parseInt("0x11", 0)
parseInt("0x11")
See also isNaN, parseFloat, Object.valueOf
Chapter 2, Top-Level Properties and Functions 223
String
String
Converts the specified object to a string.
Syntax String( obj)
Parameter
Description String is a top-level function and is not associated with any object.
The String method converts the value of any object into a string; it returns
the same value as the toString method of an individual object.
When the object is a Date object, String returns a more readable string
representation of the date. Its format is: Thu Aug 18 04:37:43 Pacific Daylight
Time 1983.
Example The following example converts the Date object to a readable string.
D = new Date (430054663215)
alert (String(D))
This displays a dialog box containing "Thu Aug 18 04:37:43 GMT-0700 (Pacific
Daylight Time) 1983."
See also String
undefined
The value undefined.
Syntax undefined
Core function
Implemented in JavaScript 1.2, NES 3.0
ECMA version ECMA-262
obj An object.
Core property
Implemented in JavaScript 1.3
ECMA version ECMA-262
unescape
224 Core JavaScript Reference
Description undefined is a top-level property and is not associated with any object.
A variable that has not been assigned a value is of type undefined. A method or
statement also returns undefined if the variable that is being evaluated does
not have an assigned value.
You can use undefined to determine whether a variable has a value. In the
following code, the variable x is not defined, and the if statement evaluates to
true.
var x
if(x == undefined) {
// these statements execute
}
undefined is also a primitive value.
unescape
Returns the ASCII string for the specified hexadecimal encoding value.
Syntax unescape( string)
Parameters
Description unescape is a top-level function and is not associated with any object.
The string returned by the unescape function is a series of characters in the
ISO-Latin-1 character set.
The escape and unescape methods do not use Unicode as specified by the
ECMA specification. For information, see the description of “Unicode” on
page 213.
Core function
Implemented in JavaScript 1.0, NES 1.0
ECMA version ECMA-262 compatible, except for Unicode characters.
string A string containing characters in the form "%xx", where xx is a
2-digit hexadecimal number.
Chapter 2, Top-Level Properties and Functions 225
unescape
Examples The following example returns "&":
unescape("%26")
The following example returns "!#":
unescape("%21%23")
See also escape
unescape
226 Core JavaScript Reference
2
• Statements
• Operators
228 Core JavaScript Reference
Chapter 3, Statements 229
Language Elements
Ch a p t e r
3 Statements
Chapter 3
break
Use the break statement to terminate a loop, switch, or label statement.
Terminates the current loop, switch, or label statement and transfers program
control to the statement following the terminated loop.
Syntax break [ label]
Parameter
Description The break statement includes an optional label that allows the program to
break out of a labeled statement. The statements in a labeled statement can be
of any type.
Examples Example 1. The following function has a break statement that terminates the
while loop when e 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
}
Example 2. In the following example, a statement labeled checkiandj
contains a statement labeled checkj. If break is encountered, the program
breaks out of the checkj statement and continues with the remainder of the
checkiandj statement. If break had a label of checkiandj, the program
would break out of the checkiandj statement and continue at the statement
following checkiandj.
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
label Identifier associated with the label of the statement.
comment
232 Core JavaScript Reference
checkiandj :
if (4==i) {
document.write("You’ve entered " + i + ".<BR>");
checkj :
if (2==j) {
document.write("You’ve entered " + j + ".<BR>");
break checkj;
document.write("The sum is " + (i+j) + ".<BR>");
}
document.write(i + "" + j + "=" + (ij) + ".<BR>");
}
See also continue, label, switch
comment
Notations by the author to explain what a script does. Comments are ignored
by the interpreter.
Syntax // comment text
/* multiple line comment text */
Description JavaScript supports Java-style comments:
• Comments on a single line are preceded by a double-slash (//).
• Comments that span multiple lines are preceded by a /* and followed by a
*/.
Examples // This is a singleline comment.
/* This is a multipleline comment. It can be of any length, and
you can put whatever you want here. */
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
Chapter 3, Statements 233
continue
continue
Restarts a while, dowhile, for, or label statement.
Syntax continue [ label]
Parameter
Description In contrast to the break statement, continue does not terminate the execution
of the loop entirely: instead,
• In a while loop, it jumps back to the condition.
• In a for loop, it jumps to the update expression.
The continue statement can now include an optional label that allows the
program to terminate execution of a labeled statement and continue to the
specified labeled statement. This type of continue must be in a looping
statement identified by the label used by continue.
Examples Example 1. 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
}
Example 2. In the following example, a statement labeled checkiandj
contains a statement labeled checkj. If continue is encountered, the program
continues at the top of the checkj statement. Each time continue is
encountered, checkj reiterates until its condition returns false. When false is
returned, the remainder of the checkiandj statement is completed.
checkiandj reiterates until its condition returns false. When false is returned,
the program continues at the statement following checkiandj.
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
label Identifier associated with the label of the statement.
do...while
234 Core JavaScript Reference
If continue had a label of checkiandj, the program would continue at the top
of the checkiandj statement.
checkiandj :
while (i<4) {
document.write(i + "<BR>");
i+=1;
checkj :
while (j>4) {
document.write(j + "<BR>");
j=1;
if ((j%2)==0)
continue checkj;
document.write(j + " is odd.<BR>");
}
document.write("i = " + i + "<br>");
document.write("j = " + j + "<br>");
}
See also break, label
do...while
Executes the specified statements until the test condition evaluates to false.
Statements execute at least once.
Syntax do
statements
while ( condition);
Parameters
Implemented in JavaScript 1.2, NES 3.0
statements Block of statements that is executed at least once and is re-executed
each time the condition evaluates to true.
condition Evaluated after each pass through the loop. If condition
evaluates to true, the statements in the preceding block are reexecuted.
When condition evaluates to false, control passes to
the statement following do while.
Chapter 3, Statements 235
export
Examples In the following example, the do loop iterates at least once and reiterates until i
is no longer less than 5.
do {
i+=1
document.write(i);
while (i<5);
export
Allows a signed script to provide properties, functions, and objects to other
signed or unsigned scripts.
Syntax export name1, name2, ..., nameN
export *
Parameters
Description Typically, information in a signed script is available only to scripts signed by
the same principals. By exporting properties, functions, or objects, a signed
script makes this information available to any script (signed or unsigned). The
receiving script uses the companion import statement to access the information.
See also import
for
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.
Implemented in JavaScript 1.2, NES 3.0
nameN List of properties, functions, and objects to be exported.
* Exports all properties, functions, and objects from the script.
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
for...in
236 Core JavaScript Reference
Syntax for ([initialexpression]; [condition]; [incrementexpression])
{
statements
}
Parameters
Examples The following for statement starts by declaring the variable i and initializing it
to 0. It checks that i is less than nine, performs the two succeeding statements,
and increments i by 1 after each pass through the loop.
for (var i = 0; i < 9; i++) {
n += i
myfunc(n)
}
for...in
Iterates a specified variable over all the properties of an object. For each
distinct property, JavaScript executes the specified statements.
Syntax for ( variable in object) {
statements
}
initialexpression Statement or variable declaration. Typically used to initialize a
counter variable. This expression may optionally declare new
variables with the var keyword. These variables are local to
the function, not to the loop.
condition Evaluated on each pass through the loop. If this condition
evaluates to true, the statements in statements are
performed. This conditional test is optional. If omitted, the
condition always evaluates to true.
incrementexpression Generally used to update or increment the counter variable.
statements Block of statements that are executed as long as condition
evaluates to true. This can be a single statement or multiple
statements. Although not required, it is good practice to indent
these statements from the beginning of the for statement.
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
Chapter 3, Statements 237
function
Parameters
Examples 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 show_props(obj, objName) {
var result = ""
for (var i in obj) {
result += objName + "." + i + " = " + obj[i] + "\n"
}
return result
}
function
Declares a function with the specified parameters. Acceptable parameters
include strings, numbers, and objects.
Syntax function name([ param] [, param] [..., param]) {
statements
}
You can also define functions using the Function constructor; see “Function”
on page 79.
Parameters
variable Variable to iterate over every property, declared with the var
keyword. This variable is local to the function, not to the loop.
object Object for which the properties are iterated.
statements Specifies the statements to execute for each property.
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
name The function name.
param The name of an argument to be passed to the function. A function
can have up to 255 arguments.
statements The statements which comprise the body of the function.
if...else
238 Core JavaScript Reference
Description To return a value, the function must have a return statement that specifies the
value to return.
A function created with the function statement is a Function object and
has all the properties, methods, and behavior of Function objects. See
“Function” on page 79 for detailed information on functions.
Examples The following code declares a function that 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
}
See also “Function” on page 79
if...else
Executes a set of statements if a specified condition is true. If the condition is
false, another set of statements can be executed.
Syntax if ( condition) {
statements1
}
[else {
statements2
}]
Parameters
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
condition Can be any JavaScript expression that evaluates to true or false.
Parentheses are required around the condition. If condition
evaluates to true, the statements in statements1 are executed.
statements1,
statements2
Can be any JavaScript statements, including further nested if
statements. Multiple statements must be enclosed in braces.
Chapter 3, Statements 239
import
Description You should not use simple assignments in a conditional statement. For
example, do not use the following code:
if(x = y)
{
/* do the right thing */
}
If you need to use an assignment in a conditional statement, put additional
parentheses around the assignment. For example, use if( (x = y) ).
Backward
Compatibility
JavaScript 1.2 and earlier versions. You can use simple assignments in a
conditional statement. An assignment operator in a conditional statement is
converted to an equality operator. For example, if(x = y) is converted to
if(x == y).
Examples if (cipher_char == from_char) {
result = result + to_char
x++}
else
result = result + clear_char
import
Allows a script to import properties, functions, and objects from a signed script
that has exported the information.
Syntax import objectName. name1, objectName. name2, ..., objectName. nameN
import objectName.*
Parameters
Implemented in JavaScript 1.2, NES 3.0
objectName Name of the object that will receive the imported names.
name1,
name2,
nameN
List of properties, functions, and objects to import from the export
file.
* Imports all properties, functions, and objects from the export script.
label
240 Core JavaScript Reference
Description The objectName parameter is the name of the object that will receive the
imported names. For example, if f and p have been exported, and if obj is an
object from the importing script, the following code makes f and p accessible
in the importing script as properties of obj.
import obj.f, obj.p
Typically, information in a signed script is available only to scripts signed by
the same principals. By exporting (using the export statement) properties,
functions, or objects, a signed script makes this information available to any
script (signed or unsigned). The receiving script uses the import statement to
access the information.
The script must load the export script into a window, frame, or layer before it
can import and use any exported properties, functions, and objects.
See also export
label
Provides a statement with an identifier that lets you refer to it elsewhere in your
program.
For example, you can use a label to identify a loop, and then use the break or
continue statements to indicate whether a program should interrupt the loop
or continue its execution.
Syntax label :
statements
Parameter
Examples For an example of a label statement using break, see break. For an example
of a label statement using continue, see continue.
See also break, continue
Implemented in JavaScript 1.2, NES 3.0
label Any JavaScript identifier that is not a reserved word.
statements Block of statements. break can be used with any labeled
statement, and continue can be used with looping labeled
statements.
Chapter 3, Statements 241
return
return
Specifies the value to be returned by a function.
Syntax return expression
Parameters
Examples The following function returns the square of its argument, x, where x is a
number.
function square(x) {
return x * x
}
switch
Allows a program to evaluate an expression and attempt to match the
expression’s value to a case label.
Syntax switch ( expression){
case label :
statements;
break;
case label :
statements;
break;
...
default : statements;
}
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
expression The expression to return.
Implemented in JavaScript 1.2, NES 3.0
switch
242 Core JavaScript Reference
Parameters
Description If a match is found, the program executes the associated statement. If multiple
cases match the provided value, the first case that matches is selected, even if
the cases are not equal to each other.
The program first looks for a label matching the value of expression and then
executes the associated statement. If no matching label is found, the program
looks for the optional default statement, and if found, executes the associated
statement. If no default statement is found, the program continues execution at
the statement following the end of switch.
The optional break statement associated with each case label ensures that the
program breaks out of switch once the matched statement is executed and
continues execution at the statement following switch. If break is omitted, the
program continues execution at the next statement in the switch statement.
Examples In the following example, if expression evaluates to “Bananas”, the program
matches the value with case “Bananas” and executes the associated statement.
When break is encountered, the program breaks out of switch and executes
the statement following switch. If break were omitted, the statement for case
“Cherries” would also be executed.
switch (i) {
case "Oranges" :
document.write("Oranges are $0.59 a pound.<BR>");
break;
case "Apples" :
document.write("Apples are $0.32 a pound.<BR>");
break;
case "Bananas" :
document.write("Bananas are $0.48 a pound.<BR>");
break;
case "Cherries" :
document.write("Cherries are $3.00 a pound.<BR>");
break;
default :
document.write("Sorry, we are out of " + i + ".<BR>");
}
document.write("Is there anything else you’d like?<BR>");
expression Value matched against label.
label Identifier used to match against expression.
statements Block of statements that is executed once if expression matches
label.
Chapter 3, Statements 243
throw
throw
Throws a user-defined exception.
Syntax throw expression
Parameters
Description Use the throw statement to throw an exception. When you throw an
exception, an expression specifies the value of the exception. The following
code throws several exceptions.
throw "Error2" // generates an exception with a string value
throw 42 // generates an exception with the value 42
throw true // generates an exception with the value true
Examples Example 1: Throw an object. You can specify an object when you throw an
exception. You can then reference the object’s properties in the catch block.
The following example creates an object myUserException of type
UserException and uses it in a throw statement.
function UserException (message) {
this.message=message
this.name="UserException"
}
function getMonthName (mo) {
mo=mo1 // Adjust month number for array index (1=Jan, 12=Dec)
var months=new Array("Jan","Feb","Mar","Apr","May","Jun","Jul",
"Aug","Sep","Oct","Nov","Dec")
if (months[mo] != null) {
return months[mo]
} else {
myUserException=new UserException("InvalidMonthNo")
throw myUserException
}
}
try {
// statements to try
monthName=getMonthName(myMonth)
}
catch (e) {
monthName="unknown"
logMyErrors(e.message,e.name) // pass exception object to err handler
}
Implemented in JavaScript 1.4
expression The value to throw.
throw
244 Core JavaScript Reference
Example 2: Throw an object. The following example tests an input string for
a U.S. zip code. If the zip code uses an invalid format, the throw statement
throws an exception by creating an object of type
ZipCodeFormatException.
/*
* Creates a ZipCode object.
*
* Accepted formats for a zip code are:
* 12345
* 123456789
* 123456789
* 12345 6789
*
* If the argument passed to the ZipCode constructor does not
* conform to one of these patterns, an exception is thrown.
*/
function ZipCode(zip) {
zip = new String(zip);
pattern = /[09]{5}([ ]?[09]{4})?/;
if (pattern.test(zip)) {
// zip code value will be the first match in the string
this.value = zip.match(pattern)[0]
this.valueOf = new Function("return this.value");
this.toString = new Function("return String(this.value)");
} else {
throw new ZipCodeFormatException(zip);
}
}
function ZipCodeFormatException(value) {
this.value = value;
this.message =
"does not conform to the expected format for a zip code";
this.toString =
new Function("return this.value +\":\" + this.message");
}
/*
* This could be in a script that validates address data
* for US addresses.
*/
var ZIPCODE_INVALID = 1;
var ZIPCODE_UNKNOWN_ERROR = 2;
Chapter 3, Statements 245
throw
function verifyZipCode(z) {
try {
z = new ZipCode(z);
}
catch (e) {
if (e instanceof ZipCodeFormatException) {
return ZIPCODE_INVALID;
}
else {
return ZIPCODE_UNKNOWN_ERROR;
}
}
return z;
}
a=verifyZipCode(95060) // returns 95060
b=verifyZipCode(9560) // returns 1
c=verifyZipCode("a") // returns 1
d=verifyZipCode("95060") // returns 95060
e=verifyZipCode("95060 1234") // returns 95060 1234
Example 3: Rethrow an exception. You can use throw to rethrow an
exception after you catch it. The following example catches an exception with
a numeric value and rethrows it if the value is over 50. The rethrown exception
propagates up to the enclosing function or to the top level so that the user sees
it.
try {
throw n // throws an exception with a numeric value
}
catch (e) {
if (e <= 50) {
// statements to handle exceptions 150
}
else {
// cannot handle this exception, so rethrow
throw e
}
}
See also try...catch
try...catch
246 Core JavaScript Reference
try...catch
Marks a block of statements to try, and specifies a response should an
exception be thrown.
Syntax try {
statements
}
[catch ( catchID) {
statements
}]
[finally {
statements
}]
Parameters
Description The try...catch statement consists of a try block, which contains one or
more statements, and a catch block, containing statements that specify what
to do if an exception is thrown in the try block. That is, you want the try
block to succeed, and if it does not succeed, you want control to pass to the
catch block. If any statement within the try block (or in a function called
from within the try block) throws an exception, control immediately shifts to
the catch block. If no exception is thrown in the try block succeed, the
catch block is skipped. The finally block executes after the try and
catch blocks execute but before the statements following the try...catch
statement.
You can nest one or more try...catch statements. If an inner try...catch
statement does not have a catch block, the enclosing try...catch
statement’s catch block is entered.
Implemented in JavaScript 1.4
statements Block of statements that executes once. The statements can be
declarative statements (such as var) or executable statements (such
as for).
catch A block of statements to be executed if an exception is thrown in
the try block.
catchID An identifier to hold an exception object.
finally A block of statements that is executed before the try...catch
statement completes. This block of statements executes whether or
not an exception was thrown or caught.
Chapter 3, Statements 247
try...catch
You also use the try...catch statement to handle Java exceptions. See the
Core JavaScript Guide for information on Java exceptions.
The catch Block. The catch block is entered when any exception is thrown.
For example, the following code throws an exception. When the exception
occurs, control transfers to the catch block.
try {
throw "myException" // generates an exception
}
catch (e) {
// statements to handle any exceptions
logMyErrors(e) // pass exception object to error handler
}
The catch Block’s Identifier. When an exception is thrown in the try block,
the catchID holds the value specified by the throw statement; you can use
this identifier to get information about the exception that was thrown.
JavaScript creates this identifier when the catch block is entered; the identifier
lasts only for the duration of the catch block; after the catch block finishes
executing, the identifier is no longer available.
The finally Block. The finally block contains statements to execute after
the try and catch blocks execute but before the statements following the
try...catch statement. The finally block executes whether or not an
exception is thrown. If an exception is thrown, the statements in the finally
block execute even if no catch block handles the exception.
You can use the finally block to make your script fail gracefully when an
exception occurs; for example, you may need to release a resource that your
script has tied up. The following example opens a file and then executes
statements that use the file (server-side JavaScript allows you to access files). If
an exception is thrown while the file is open, the finally block closes the
file before the script fails.
try {
openMyFile() // tie up a resource
writeMyFile(theData)
}
finally {
closeMyFile() // always close the resource
}
Examples See the examples for throw.
See also throw
var
248 Core JavaScript Reference
var
Declares a variable, optionally initializing it to a value.
Syntax var varname [= value] [..., varname [= value] ]
Parameters
Description 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 in the following situations:
• If a global variable of the same name exists.
• If recursive or multiple functions use variables with the same name.
Examples var num_hits = 0, cust_no = 0
while
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.
Syntax while ( condition) {
statements
}
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
varname Variable name. It can be any legal identifier.
value Initial value of the variable and can be any legal expression.
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
Chapter 3, Statements 249
with
Parameters
Examples 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:
• After the first pass: n = 1 and x = 1
• After the second pass: n = 2 and x = 3
• After the third pass: n = 3 and x = 6
After completing the third pass, the condition n < 3 is no longer true, so the
loop terminates.
with
Establishes the default object for a set of statements.
Syntax with ( object){
statements
}
condition Evaluated before each pass through the loop. If this condition
evaluates to true, the statements in the succeeding block are
performed. When condition evaluates to false, execution
continues with the statement following statements.
statements Block of statements that are executed as long as the condition
evaluates to true. Although not required, it is good practice to
indent these statements from the beginning of the statement.
Implemented in JavaScript 1.0, NES 2.0
ECMA version ECMA-262
with
250 Core JavaScript Reference
Parameters
Description JavaScript looks up any unqualified names within the set of statements to
determine if the names are properties of the default object. If an unqualified
name matches a property, then the property is used in the statement; otherwise,
a local or global variable is used.
Examples 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)
}
object Specifies the default object to use for the statements. The
parentheses around object are required.
statements Any block of statements.
Chapter 4, Operators 251
Ch a p t e r
4 Operators
Chapter 4
Assignment Operators
An assignment operator assigns a value to its left operand based on the value of
its right operand.
Special
Operators
?: Performs a simple "if...then...else"
, Evaluates two expressions and returns the result of the second
expression.
delete Deletes an object, an object’s property, or an element at a specified index
in an array.
in Returns true if the specified property is in the specified object.
instanceof Returns true if the specified object is of the specified object type.
new Creates an instance of a user-defined object type or of one of the built-in
object types.
this Keyword that you can use to refer to the current object.
typeof Returns a string indicating the type of the unevaluated operand.
void Specifies an expression to be evaluated without returning a value.
Table 4.1 JavaScript operators. (Continued)
Operator
category
Operator Description
Implemented in JavaScript 1.0
ECMA version ECMA-262
Chapter 4, Operators 255
Assignment Operators
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
assignment operators are usually shorthand for standard operations, as shown
in the following table.
In unusual situations, the assignment operator is not identical to the Meaning
expression in Table 4.2. When the left operand of an assignment operator itself
contains an assignment operator, the left operand is evaluated only once. For
example:
a[i++] += 5 //i is evaluated only once
a[i++] = a[i++] + 5 //i is evaluated twice
Table 4.2 Assignment operators
Shorthand operator Meaning
x += y x = x + y
x = y x = x y
x *= y x = x * y
x /= y x = x / y
x %= y x = x % y
x <<= y x = x << y
x >>= y x = x >> y
x >>>= y x = x >>> y
x &= y x = x & y
x ^= y x = x ^ y
x |= y x = x | y
Comparison Operators
256 Core JavaScript Reference
Comparison Operators
A comparison operator compares its operands and returns a logical value based
on whether the comparison is true.
The operands can be numerical or string values. Strings are compared based on
standard lexicographical ordering, using Unicode values.
A Boolean value is returned as the result of the comparison.
• Two strings are equal when they have the same sequence of characters,
same length, and same characters in corresponding positions.
• Two numbers are equal when they are numerically equal (have the same
number value). NaN is not equal to anything, including NaN. Positive and
negative zeros are equal.
• Two objects are equal if they refer to the same Object.
• Two Boolean operands are equal if they are both true or false.
• Null and Undefined types are equal.
Implemented in JavaScript 1.0
JavaScript 1.3: Added the === and !== operators.
JavaScript 1.4: Deprecated == for comparison of two JSObject
objects. Use the JSObject.equals method.
ECMA version ECMA-262 includes all comparison operators except === and !==.
Chapter 4, Operators 257
Comparison Operators
The following table describes the comparison operators.
Using the Equality Operators
The standard equality operators (== and !=) compare two operands without
regard to their type. The strict equality operators (=== and !==) perform
equality comparisons on operands of the same type. Use strict equality
operators if the operands must be of a specific type as well as value or if the
exact type of the operands is important. Otherwise, use the standard equality
operators, which allow you to compare the identity of two operands even if
they are not of the same type.
Table 4.3 Comparison operators
Operator Description Examples returning truea
Equal (==) Returns true if the operands are equal. If the two
operands are not of the same type, JavaScript
attempts to convert the operands to an
appropriate type for the comparison.
3 == var1
"3" == var1
3 == ’3’
Not equal (!=) Returns true if the operands are not equal. If the
two operands are not of the same type, JavaScript
attempts to convert the operands to an
appropriate type for the comparison.
var1 != 4
var1 != "3"
Strict equal (===) Returns true if the operands are equal and of the
same type.
3 === var1
Strict not equal (!==) Returns true if the operands are not equal and/or
not of the same type.
var1 !== "3"
3 !== ’3’
Greater than (>) Returns true if the left operand is greater than the
right operand.
var2 > var1
Greater than or equal
(>=)
Returns true if the left operand is greater than or
equal to the right operand.
var2 >= var1
var1 >= 3
Less than (<) Returns true if the left operand is less than the
right operand.
var1 < var2
Less than or equal (<=) Returns true if the left operand is less than or
equal to the right operand.
var1 <= var2
var2 <= 5
a. These examples assume that var1 has been assigned the value 3 and var2 has been assigned the value 4.
Comparison Operators
258 Core JavaScript Reference
When type conversion is needed, JavaScript converts String, Number,
Boolean, or Object operands as follows.
• When comparing a number and a string, the string is converted to a number
value. JavaScript attempts to convert the string numeric literal to a Number
type value. First, a mathematical value is derived from the string numeric
literal. Next, this value is rounded to nearest Number type value.
• If one of the operands is Boolean, the Boolean operand is converted to 1
if it is true and +0 if it is false.
• If an object is compared with a number or string, JavaScript attempts to
return the default value for the object. Operators attempt to convert the
object to a primitive value, a String or Number value, using the valueOf
and toString methods of the objects. If this attempt to convert the object
fails, a runtime error is generated.
Backward
Compatibility
The behavior of the standard equality operators (== and !=) depends on the
JavaScript version.
JavaScript 1.4 and later versions. You cannot use the standard equality
operator (==) to compare instances of JSObject. Use the
JSObject.equals method for such comparisons. JSObject.equals is
available for this purpose in all previous versions of JavaScript.
JavaScript 1.2. The standard equality operators (== and !=) do not perform a
type conversion before the comparison is made. The strict equality operators
(=== and !==) are unavailable.
JavaScript 1.1 and earlier versions. The standard equality operators (== and
!=) perform a type conversion before the comparison is made. The strict
equality operators (=== and !==) are unavailable.
Chapter 4, Operators 259
Arithmetic Operators
Arithmetic 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 most other programming languages, except
the / operator returns a floating-point division in JavaScript, not a truncated
division as it does in languages such as C or Java. For example:
1/2 //returns 0.5 in JavaScript
1/2 //returns 0 in Java
% (Modulus)
The modulus operator is used as follows:
var1 % var2
The modulus operator returns the first operand modulo the second operand,
that is, var1 modulo var2, in the preceding statement, where var1 and var2
are variables. The modulo function is the integer remainder of dividing var1 by
var2. For example, 12 % 5 returns 2.
++ (Increment)
The increment operator is used as follows:
var++ or ++ var
This operator increments (adds one to) its operand and returns a value. If used
postfix, with operator after operand (for example, x++), then it returns the
value before incrementing. If used prefix with operator before operand (for
example, ++x), then it returns the value after incrementing.
Implemented in JavaScript 1.0
ECMA version ECMA-262
Bitwise Operators
260 Core JavaScript Reference
For example, if x is three, then the statement y = x++ sets y to 3 and
increments x to 4. If x is 3, then the statement y = ++x increments x to 4 and
sets y to 4.
-- (Decrement)
The decrement operator is used as follows:
var or var
This operator decrements (subtracts one from) its operand and returns a value.
If used postfix (for example, x--), then it returns the value before decrementing.
If used prefix (for example, --x), then it returns the value after decrementing.
For example, if x is three, then the statement y = x sets y to 3 and
decrements x to 2. If x is 3, then the statement y = x decrements x to 2 and
sets y to 2.
- (Unary Negation)
The unary negation operator precedes its operand and negates it. For example,
y = x negates the value of x and assigns that to y; that is, if x were 3, y
would get the value -3 and x would retain the value 3.
Bitwise Operators
Bitwise operators treat their operands as a set of 32 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.
Chapter 4, Operators 261
Bitwise Operators
The following table summarizes JavaScript’s bitwise operators:
Bitwise Logical Operators
Conceptually, the bitwise logical operators work as follows:
• The operands are converted to thirty-two-bit integers and expressed by a
series of bits (zeros and ones).
• Each bit in the first operand is paired with the corresponding bit in the
second operand: first bit to first bit, second bit to second bit, and so on.
• The operator is applied to each pair of bits, and the result is constructed
bitwise.
Table 4.4 Bitwise operators
Operator Usage Description
Bitwise AND a & b Returns a one in each bit position for which
the corresponding bits of both operands are
ones.
Bitwise OR a | b Returns a one in each bit position for which
the corresponding bits of either or both
operands are ones.
Bitwise XOR a ^ b Returns a one in each bit position for which
the corresponding bits of either but not both
operands are ones.
Bitwise NOT ~ a Inverts the bits of its operand.
Left shift a << b Shifts a in binary representation b bits to
left, shifting in zeros from the right.
Sign-propagating right
shift
a >> b Shifts a in binary representation b bits to
right, discarding bits shifted off.
Zero-fill right shift a >>> b Shifts a in binary representation b bits to
the right, discarding bits shifted off, and
shifting in zeros from the left.
Implemented in JavaScript 1.0
ECMA version ECMA-262
Bitwise Operators
262 Core JavaScript Reference
For example, the binary representation of nine is 1001, and the binary
representation of fifteen is 1111. So, when the bitwise operators are applied to
these values, the results are as follows:
• 15 & 9 yields 9 (1111 & 1001 = 1001)
• 15 | 9 yields 15 (1111 | 1001 = 1111)
• 15 ^ 9 yields 6 (1111 ^ 1001 = 0110)
Bitwise Shift Operators
The bitwise shift operators take two operands: the first is a quantity to be
shifted, and the second specifies the number of bit positions by which the first
operand is to be shifted. The direction of the shift operation is controlled by the
operator used.
Shift operators convert their operands to thirty-two-bit integers and return a
result of the same type as the left operator.
<< (Left Shift)
This operator shifts the first operand the specified number of bits to the left.
Excess bits shifted off to the left are discarded. Zero bits are shifted in from the
right.
For example, 9<<2 yields thirty-six, because 1001 shifted two bits to the left
becomes 100100, which is thirty-six.
Implemented in JavaScript 1.0
ECMA version ECMA-262
Chapter 4, Operators 263
Logical Operators
>> (Sign-Propagating Right Shift)
This operator shifts the first operand the specified number of bits to the right.
Excess bits shifted off to the right are discarded. Copies of the leftmost bit are
shifted in from the left.
For example, 9>>2 yields two, because 1001 shifted two bits to the right
becomes 10, which is two. Likewise, -9>>2 yields -3, because the sign is
preserved.
>>> (Zero-Fill Right Shift)
This operator shifts the first operand the specified number of bits to the right.
Excess bits shifted off to the right are discarded. Zero bits are shifted in from
the left.
For example, 19>>>2 yields four, because 10011 shifted two bits to the right
becomes 100, which is four. For non-negative numbers, zero-fill right shift and
sign-propagating right shift yield the same result.
Logical Operators
Logical operators are typically used with Boolean (logical) values; when they
are, they return a Boolean value. However, the && and || operators actually
return the value of one of the specified operands, so if these operators are used
with non-Boolean values, they may return a non-Boolean value.
Implemented in JavaScript 1.0
ECMA version ECMA-262
Logical Operators
264 Core JavaScript Reference
The logical operators are described in the following table.
Examples of expressions that can be converted to false are those that evaluate
to null, 0, the empty string (“”), or undefined.
Even though the && and || operators can be used with operands that are not
Boolean values, they can still be considered Boolean operators since their
return values can always be converted to Boolean values.
Short-Circuit Evaluation. As logical expressions are evaluated left to right,
they are tested for possible “short-circuit” evaluation using the following rules:
• false && anything is short-circuit evaluated to false.
• true || anything is short-circuit evaluated to true.
The rules of logic guarantee that these evaluations are always correct. Note that
the anything part of the above expressions is not evaluated, so any side effects
of doing so do not take effect.
Table 4.5 Logical operators
Operator Usage Description
&& expr1 && expr2 (Logical AND) Returns expr1 if it can be
converted to false; otherwise, returns expr2.
Thus, when used with Boolean values, && returns
true if both operands are true; otherwise, returns
false.
|| expr1 || expr2 (Logical OR) Returns expr1 if it can be converted
to true; otherwise, returns expr2. Thus, when
used with Boolean values, || returns true if either
operand is true; if both are false, returns false.
! ! expr (Logical NOT) Returns false if its single operand
can be converted to true; otherwise, returns true.
Chapter 4, Operators 265
Logical Operators
Backward
Compatibility
JavaScript 1.0 and 1.1. The && and || operators behave as follows:
Examples The following code shows examples of the && (logical AND) operator.
a1=true && true // t && t returns true
a2=true && false // t && f returns false
a3=false && true // f && t returns false
a4=false && (3 == 4) // f && f returns false
a5="Cat" && "Dog" // t && t returns Dog
a6=false && "Cat" // f && t returns false
a7="Cat" && false // t && f returns false
The following code shows examples of the || (logical OR) operator.
o1=true || true // t || t returns true
o2=false || true // f || t returns true
o3=true || false // t || f returns true
o4=false || (3 == 4) // f || f returns false
o5="Cat" || "Dog" // t || t returns Cat
o6=false || "Cat" // f || t returns Cat
o7="Cat" || false // t || f returns Cat
The following code shows examples of the ! (logical NOT) operator.
n1=!true // !t returns false
n2=!false // !f returns true
n3=!"Cat" // !t returns false
Operator Behavior
&& If the first operand (expr1) can be converted to false, the &&
operator returns false rather than the value of expr1.
|| If the first operand (expr1) can be converted to true, the ||
operator returns true rather than the value of expr1.
String Operators
266 Core JavaScript Reference
String Operators
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.
Special Operators
?: (Conditional operator)
The conditional operator is the only JavaScript operator that takes three
operands. This operator is frequently used as a shortcut for the if statement.
Syntax condition ? expr1 : expr2
Parameters
Description If condition is true, the operator returns the value of expr1; otherwise, it
returns the value of expr2. For example, to display a different message based
on the value of the isMember variable, you could use this statement:
document.write ("The fee is " + (isMember ? "$2.00" : "$10.00"))
Implemented in JavaScript 1.0
ECMA version ECMA-262
Implemented in JavaScript 1.0
ECMA version ECMA-262
condition An expression that evaluates to true or false
expr1, expr2 Expressions with values of any type.
Chapter 4, Operators 267
Special Operators
, (Comma operator)
The comma operator evaluates both of its operands and returns the value of the
second operand.
Syntax expr1, expr2
Parameters
Description You can use the comma operator when you want to include multiple
expressions in a location that requires a single expression. The most common
usage of this operator is to supply multiple parameters in a for loop.
For example, if a is a 2-dimensional array with 10 elements on a side, the
following code uses the comma operator to increment two variables at once.
The code prints the values of the diagonal elements in the array:
for (var i=0, j=9; i <= 9; i++, j)
document.writeln("a["+i+","+j+"]= " + a[i,j])
delete
The delete operator deletes an object, an object’s property, or an element at a
specified index in an array.
Syntax delete objectName
delete objectName. property
delete objectName[ index]
delete property // legal only within a with statement
Parameters
Implemented in JavaScript 1.0
ECMA version ECMA-262
expr1, expr2 Any expressions
Implemented in JavaScript 1.2, NES 3.0
ECMA version ECMA-262
objectName The name of an object.
property The property to delete.
index An integer representing the array index to delete.
Special Operators
268 Core JavaScript Reference
Description The fourth form is legal only within a with statement, to delete a property from
an object.
You can use the delete operator to delete variables declared implicitly but not
those declared with the var statement.
If the delete operator succeeds, it sets the property or element to undefined.
The delete operator returns true if the operation is possible; it returns false if
the operation is not possible.
x=42
var y= 43
myobj=new Number()
myobj.h=4 // create property h
delete x // returns true (can delete if declared implicitly)
delete y // returns false (cannot delete if declared with var)
delete Math.PI // returns false (cannot delete predefined properties)
delete myobj.h // returns true (can delete userdefined properties)
delete myobj // returns true (can delete objects)
Deleting array elements. When you delete an array element, the array length
is not affected. For example, if you delete a[3], a[4] is still a[4] and a[3] is
undefined.
When the delete operator removes an array element, that element is no
longer in the array. In the following example, trees[3] is removed with delete.
trees=new Array("redwood","bay","cedar","oak","maple")
delete trees[3]
if (3 in trees) {
// this does not get executed
}
If you want an array element to exist but have an undefined value, use the
undefined keyword instead of the delete operator. In the following
example, trees[3] is assigned the value undefined, but the array element still
exists:
trees=new Array("redwood","bay","cedar","oak","maple")
trees[3]=undefined
if (3 in trees) {
// this gets executed
}
Chapter 4, Operators 269
Special Operators
in
The in operator returns true if the specified property is in the specified object.
Syntax propNameOrNumber in objectName
Parameters
Description The following examples show some uses of the in operator.
// Arrays
trees=new Array("redwood","bay","cedar","oak","maple")
0 in trees // returns true
3 in trees // returns true
6 in trees // returns false
"bay" in trees // returns false (you must specify the index number,
// not the value at that index)
"length" in trees // returns true (length is an Array property)
// Predefined objects
"PI" in Math // returns true
myString=new String("coral")
"length" in myString // returns true
// Custom objects
mycar = {make:"Honda",model:"Accord",year:1998}
"make" in mycar // returns true
"model" in mycar // returns true
You must specify an object on the right side of the in operator. For example,
you can specify a string created with the String constructor, but you cannot
specify a string literal.
color1=new String("green")
"length" in color1 // returns true
color2="coral"
"length" in color2 // generates an error (color is not a String object)
Implemented in JavaScript 1.4
propNameOrNumber A string or numeric expression representing a property name or
array index.
objectName Name of an object.
Special Operators
270 Core JavaScript Reference
Using in with deleted or undefined properties. If you delete a property
with the delete operator, the in operator returns false for that property.
mycar = {make:"Honda",model:"Accord",year:1998}
delete mycar.make
"make" in mycar // returns false
trees=new Array("redwood","bay","cedar","oak","maple")
delete trees[3]
3 in trees // returns false
If you set a property to undefined but do not delete it, the in operator returns
true for that property.
mycar = {make:"Honda",model:"Accord",year:1998}
mycar.make=undefined
"make" in mycar // returns true
trees=new Array("redwood","bay","cedar","oak","maple")
trees[3]=undefined
3 in trees // returns true
For additional information about using the in operator with deleted array
elements, see “delete” on page 267.
instanceof
The instanceof operator returns true if the specified object is of the
specified object type.
Syntax objectName instanceof objectType
Parameters
Description Use instanceof when you need to confirm the type of an object at runtime.
For example, when catching exceptions, you can branch to different exceptionhandling
code depending on the type of exception thrown.
You must specify an object on the right side of the instanceof operator. For
example, you can specify a string created with the String constructor, but
you cannot specify a string literal.
Implemented in JavaScript 1.4
objectName Name of the object to compare to objectType.
objectType Object type.
Chapter 4, Operators 271
Special Operators
color1=new String("green")
color1 instanceof String // returns true
color2="coral"
color2 instanceof String // returns false (color is not a String object)
Examples See also the examples for throw.
Example 1. The following code uses instanceof to determine whether
theDay is a Date object. Because theDay is a Date object, the statements in
the if statement execute.
theDay=new Date(1995, 12, 17)
if (theDay instanceof Date) {
// statements to execute
}
Example 2. The following code uses instanceof to demonstrate that
String and Date objects are also of type Object (they are derived from
Object).
myString=new String()
myDate=new Date()
myString instanceof String // returns true
myString instanceof Object // returns true
myString instanceof Date // returns false
myDate instanceof Date // returns true
myDate instanceof Object // returns true
myDate instanceof String // returns false
Example 3. The following code creates an object type Car and an instance of
that object type, mycar. The instanceof operator demonstrates that the
mycar object is of type Car and of type Object.
function Car(make, model, year) {
this.make = make
this.model = model
this.year = year
}
mycar = new Car("Honda", "Accord", 1998)
a=mycar instanceof Car // returns true
b=mycar instanceof Object // returns true
Special Operators
272 Core JavaScript Reference
new
The new operator creates an instance of a user-defined object type or of one of
the built-in object types that has a constructor function.
Syntax objectName = new objectType ( param1 [, param2] ...[, paramN])
Parameters
Description Creating a user-defined object type requires two steps:
1. Define the object type by writing a function.
2. Create an instance of the object with new.
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.
You can add a property to a previously defined object type by using the
Function.prototype property. This defines a property that is shared by all
objects created with that function, rather than by just one instance of the object
type. The following code adds a color property to all objects of type car, and
then assigns a value to the color property of the object car1. For more
information, see prototype
Car.prototype.color=null
car1.color="black"
birthday.description="The day you were born"
Implemented in JavaScript 1.0
ECMA version ECMA-262
objectName Name of the new object instance.
objectType Object type. It must be a function that defines an object type.
param1...paramN Property values for the object. These properties are parameters
defined for the objectType function.
Chapter 4, Operators 273
Special Operators
Examples 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
}
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)
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)
Special Operators
274 Core JavaScript Reference
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
this
The this keyword refers to the current object. In general, in a method this
refers to the calling object.
Syntax this[. propertyName]
Examples 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)">
Implemented in JavaScript 1.0
ECMA version ECMA-262
Chapter 4, Operators 275
Special Operators
typeof
The typeof operator is used in either of the following ways:
1. typeof operand
2. typeof ( operand)
The typeof operator returns a string indicating the type of the unevaluated
operand. operand is the string, variable, keyword, or object for which the type
is to be returned. The parentheses are optional.
Suppose you define the following variables:
var myFun = new Function("5+2")
var shape="round"
var size=1
var today=new Date()
The typeof operator returns the following results for these variables:
typeof myFun is object
typeof shape is string
typeof size is number
typeof today is object
typeof dontExist is undefined
For the keywords true and null, the typeof operator returns the following
results:
typeof true is boolean
typeof null is object
For a number or string, the typeof operator returns the following results:
typeof 62 is number
typeof ’Hello world’ is string
For property values, the typeof operator returns the type of value the property
contains:
typeof document.lastModified is string
typeof window.length is number
typeof Math.LN2 is number
Implemented in JavaScript 1.1
ECMA version ECMA-262
Special Operators
276 Core JavaScript Reference
For methods and functions, the typeof operator returns results as follows:
typeof blur is function
typeof eval is function
typeof parseInt is function
typeof shape.split is function
For predefined objects, the typeof operator returns results as follows:
typeof Date is function
typeof Function is function
typeof Math is function
typeof Option is function
typeof String is function
void
The void operator is used in either of the following ways:
1. void ( expression)
2. void expression
The void operator specifies an expression to be evaluated without returning a
value. expression is a JavaScript expression to evaluate. The parentheses
surrounding the expression are optional, but it is good style to use them.
You can use the void operator to specify an expression as a hypertext link.
The expression is evaluated but is not loaded in place of the current document.
The following code creates a hypertext link that does nothing when the user
clicks it. When the user clicks the link, void(0) evaluates to 0, but that has no
effect in JavaScript.
<A HREF="javascript:void(0)">Click here to do nothing</A>
The following code creates a hypertext link that submits a form when the user
clicks it.
<A HREF="javascript:void(document.form.submit())">
Click here to submit</A>
Implemented in JavaScript 1.1
ECMA version ECMA-262
3
• Java Classes, Constructors, and
Methods
278 Core JavaScript Reference
LiveConnect Class Reference
5
Java Classes, Constructors, and
Chapter 5
Methods
This chapter documents the Java classes used for LiveConnect, along with their
constructors and methods. It is an alphabetical reference for the classes that
allow a Java object to access JavaScript code.
This reference is organized as follows:
• Full entries for each class appear in alphabetical order.
Tables included in the description of each class summarize the constructors
and methods of the class.
• Full entries for the constructors and methods of a class appear in
alphabetical order after the entry for the class.
JSException
280 Core JavaScript Reference
JSException
The public class JSException extends RuntimeException.
java.lang.Object
|
+java.lang.Throwable
|
+java.lang.Exception
|
+java.lang.RuntimeException
|
+netscape.javascript.JSException
Description JSException is an exception which is thrown when JavaScript code returns an
error.
Constructor
Summary
The netscape.javascript.JSException class has the following
constructors:
Method Summary The netscape.javascript.JSException class has the following method:
The following sections show the declaration and usage of the constructors and
method.
Backward
Compatibility
JavaScript 1.1 through 1.3. JSException had three public constructors
which optionally took a string argument, specifying the detail message or other
information for the exception. The getWrappedException method was not
available.
Constructor Description
JSException Deprecated constructors optionally let you specify a detail
message and other information.
Method Description
getWrappedException Instance method getWrappedException.
Chapter 5, Java Classes, Constructors, and Methods 281
JSException.JSException
JSException .
JSObject
The public final class netscape.javascript.JSObject extends Object.
java.lang.Object
|
+netscape.javascript.JSObject
Description JavaScript objects are wrapped in an instance of the class
netscape.javascript.JSObject and passed to Java. JSObject allows
Java to manipulate JavaScript objects.
When a JavaScript object is sent to Java, the runtime engine creates a Java
wrapper of type JSObject; when a JSObject is sent from Java to JavaScript,
the runtime engine unwraps it to its original JavaScript object type. The
JSObject class provides a way to invoke JavaScript methods and examine
JavaScript properties.
Any JavaScript data brought into Java is converted to Java data types. When the
JSObject is passed back to JavaScript, the object is unwrapped and can be used
by JavaScript code. See the Core JavaScript Guide for more information about
data type conversions.
Method Summary The netscape.javascript.JSObject class has the following methods:
Method Description
call Calls a JavaScript method.
equals Determines if two JSObject objects refer to the same
instance.
eval Evaluates a JavaScript expression.
getMember Retrieves the value of a property of a JavaScript object.
getSlot Retrieves the value of an array element of a JavaScript object.
removeMember Removes a property of a JavaScript object.
setMember Sets the value of a property of a JavaScript object.
setSlot Sets the value of an array element of a JavaScript object.
toString Converts a JSObject to a string.
Chapter 5, Java Classes, Constructors, and Methods 283
JSObject.call
The netscape.javascript.JSObject class has the following static methods:
The following sections show the declaration and usage of these methods.
call .
getMember .
Static method. Returns a JSObject for the window containing the given applet.
This method is useful in client-side JavaScript only.
Declaration public static JSObject getWindow(Applet applet)
removeMember .
4
• Reserved Words
288 Core JavaScript Reference
Appendix A, Reserved Words 289
Appendix
Appendixes
A
Appendix A Reserved Words
This appendix lists the reserved words in JavaScript.
The reserved words in this list cannot be used as JavaScript variables,
functions, methods, or object names. Some of these words are keywords used
in JavaScript; others are reserved for future use.
abstract
boolean
break
byte
case
catch
char
class
const
continue
debugger
default
delete
do
double
else
enum
export
extends
false
final
finally
float
for
function
goto
if
implements
import
in
instanceof
int
interface
long
native
new
null
package
private
protected
public
return
short
static
super
switch
synchronized
this
throw
throws
transient
true
try
typeof
var
void
volatile
while
with
290 Core JavaScript Reference
Index 291
Index
Symbols
- (bitwise NOT) operator 261
- (unary negation) operator 260
-- (decrement) operator 260
! (logical NOT) operator 264
!= (not equal) operator 257
!== (strict not equal) operator 257
$& property 159
$* property 159
$+ property 159
$_ property 159
$‘ property 159
$’ property 159
$1, ..., $9 properties 158
% (modulus) operator 259
%= operator 255
&& (logical AND) operator 264
& (bitwise AND) operator 261
&= operator 255
) 283
*/ comment 232
*= operator 255
+ (string concatenation) operator 266
++ (increment) operator 259
+= (string concatenation) operator 266
+= operator 255
/* comment 232
// comment 232
/= operator 255
< (less than) operator 257
<< (left shift) operator 261, 262
<<= operator 255
<= (less than or equal) operator 257
== (equal) operator 257
=== (strict equal) operator 257
-= operator 255
> (greater than) operator 257
>= (greater than or equal) operator 257
>> (sign-propagating right shift) operator 261,
263
>>= operator 255
>>> (zero-fill right shift) operator 261, 263
>>>= operator 255
?: (conditional) operator 266
^ (bitwise XOR) operator 261
^= operator 255
| (bitwise OR) operator 261
|= operator 255
|| (logical OR) operator 264
‚ (comma) operator 267
A
abs method 109
acos method 109
anchor method 177
anchors
creating 177
AND (&&) logical operator 264
AND (&) bitwise operator 261
apply method 83
arguments array 85
292 Core JavaScript Reference
arithmetic operators 259
% (modulus) 259
-- (decrement) 260
- (unary negation) 260
++ (increment) 259
arity property 90
Array object 16
arrays
Array object 16
creating from strings 198
deleting elements 267
dense 17
increasing length of 18
indexing 17
initial length of 17, 19
Java 98
joining 23
length of, determining 24, 190
referring to elements 17
sorting 29
asin method 110
assignment operators 254
%= 255
&= 255
*= 255
+= 255
/= 255
<<= 255
-= 255
>>= 255
>>>= 255
^= 255
|= 255
conditional statements and 239
atan2 method 111
atan method 111
B
BIG HTML tag 178
big method 178
bitwise operators 260
& (AND) 261
- (NOT) 261
<< (left shift) 261, 262
>> (sign-propagating right shift) 261, 263
>>> (zero-fill right shift) 261, 263
^ (XOR) 261
| (OR) 261
logical 261
shift 262
BLINK HTML tag 179
blink method 179
BOLD HTML tag 179
bold method 179
Boolean object 38
conditional tests and 38
break statement 231
C
callee property 87
caller property 88
call method 90
call method (LiveConnect) 283
ceil method 112
charAt method 180
charCodeAt method 181
classes, accessing Java 102, 147
className property 148
comma (‚) operator 267
comments 232
comment statement 232
comparison operators 256
!= (not equal) 257
!== (strict not equal) 257
< (less than) 257
<= (less than or equal) 257
== (equal) 257
=== (strict equal) 257
> (greater than) 257
>= (greater than or equal) 257
Index 293
compile method 160
concat method
Array object 21
String object 182
conditional (?:) operator 266
conditional tests
assignment operators and 239
Boolean objects and 38
constructor property
Array object 22
Boolean object 40
Date object 48
Function object 92
Number object 129
Object object 137
RegExp object 161
String object 182
containership
specifying default object 249
with statement and 249
continue statement 233
conventions 229
cos method 113
D
Date object 43
dates
converting to string 74
Date object 43
day of week 49
defining 43
milliseconds since 1970 77
month 51
decrement (--) operator 260
default objects, specifying 249
delete operator 267
deleting
array elements 267
objects 267
properties 267
dense arrays 17
directories, conventions used 12
do...while statement 234
document conventions 12
E
E property 114
equals method (LiveConnect 283
escape function 212
Unicode and 213
Euler’s constant 114
raised to a power 114
eval function 214
eval method
LiveConnect 283
Object object 138
exceptions
catching 246
LiveConnect 280
throwing 243
throw statement 243
try...catch statement 246
exec method 161
exp method 114
export statement 235
expressions that return no value 276
F
fixed method 183
floor method 115
fontcolor method 183
fonts
big 178
blinking 179
bold 179
fontsize method 185
for...in statement 236
294 Core JavaScript Reference
for loops
continuation of 233
syntax of 235
termination of 231
for statement 235
fromCharCode method 186
Function object 79
specifying arguments for 80
as variable value 81
functions
arguments array 85
callee property 87
caller property 88
declaring 237
Function object 79
length property 89
list of 211
nesting 81, 82
number of arguments 190
return values of 241
top-level 211
as variable value 81
function statement 237
G
getDate method 48
getDay method 49
getFullYear method 49
getHours method 50
getMember method (LiveConnect) 284
getMilliseconds method 50
getMinutes method 51
getMonth method 51
getSeconds method 52
getSlot method (LiveConnect) 284
getTime method 52
getTimezoneOffset method 53
getUTCDate method 53
getUTCDay method 54
getUTCFullYear method 54
getUTCHours method 55
getUTCMilliseconds method 56
getUTCMinutes method 56
getUTCMonth method 57
getUTCSeconds method 58
getWindow method (LiveConnect) 284
getWrappedException (LiveConnect) 281
getYear method 58
global object 211
global property 164
GMT time, defined, local time, defined 44
H
HTML tags
BIG 178
BLINK 179
BOLD 179
I
if...else statement 238
ignoreCase property 165
import statement 239
increment (++) operator 259
indexOf method 186
index property 23
Infinity property 216
in keyword 236
in operator 269
input property
Array object 23
RegExp object 165
instanceof operator 270
isFinite function 217
isNaN function 218
italics method 188
Index 295
J
JavaArray object 98
JavaClass object 102
java object 97
JavaObject object 104
JavaPackage object 106
java property 149
JavaScript
background for using 9
reserved words 289
versions and Navigator 10
join method 23
JSException class 280
JSException constructor (LiveConnect) 281
JSObject class 282
K
keywords 289
L
label statement 240
lastIndexOf method 189
lastIndex property 166
lastMatch property 167
lastParen property 168
leftContext property 168
left shift (<<) operator 261, 262
length property
arguments array 89
Array object 24
Function object 92
JavaArray object 100
String object 190
link method 191
links
anchors for 177
with no destination 276
LiveConnect
JavaArray object 98
JavaClass object 102
java object 97
JavaObject object 104
JavaPackage object 106
JSException class 280
JSObject class 282
netscape object 126
Packages object 147
sun object 210
LN10 property 116
LN2 property 116
LOG10E property 117
LOG2E property 118
logarithms
base of natural 114
natural logarithm of 10 116
logical operators 263
! (NOT) 264
&& (AND) 264
|| (OR) 264
short-circuit evaluation 264
log method 117
loops
continuation of 233
for 235
termination of 231
while 248
lowercase 175, 207
M
match method 191
Math object 107
MAX_VALUE property 129
max method 118
methods, top-level 211
MIN_VALUE property 130
min method 119
modulo function 259
296 Core JavaScript Reference
modulus (%) operator 259
multiline property 168
N
NaN property
Number object 130
top-level 218
natural logarithms
base of 114
e 114
e raised to a power 114
of 10 116
Navigator, JavaScript versions supported 10
NEGATIVE_INFINITY property 131
nesting functions 81, 82
netscape.javascript.JSException class 280
netscape.javascript.JSObject class 282
netscape object 126
netscape property 149
new operator 272
NOT (!) logical operator 264
NOT (-) bitwise operator 261
Number function 219
Number object 127
numbers
greater of two 118
identifying 218
Number object 127
obtaining integer 112
parsing from strings 220
square root 123
O
Object object 136
objects
confirming object type for 270
confirming property type for 269
creating new types 272
deleting 267
establishing default 249
getting list of properties for 237
iterating properties 236
Java, accessing 104
operators 251–276
arithmetic 259
assignment 254
bitwise 260
comparison 256
list of 251
logical 263
special 266
string 266
OR (|) bitwise operator 261
OR (||) logical operator 264
P
packages, accessing Java 106
Packages object 147
parseFloat function 220
parseInt function 221
parse method 60
PI property 120
pop method 25
Index 297
POSITIVE_INFINITY property 132
pow method 120
properties
confirming object type for 269
deleting 267
getting list of for an object 237
iterating for an object 236
top-level 211
prototype property
Array object 25
Boolean object 40
Date object 61
Function object 92
Number object 133
Object object 138
RegExp object 169
String object 193
push method 26
R
random method 121
RegExp object 151
regular expressions 151
removeMember method (LiveConnect) 284
replace method 193
reserved words 289
return statement 241
reverse method 26
rightContext property 169
round method 121
S
search method 196
selection lists
number of options 190
setDate method 61
setFullYear method 62
setHours method 63
setMember method (LiveConnect) 284
setMilliseconds method 64
setMinutes method 64
setMonth method 65
setSeconds method 66
setSlot method (LiveConnect) 285
setTime method 67
setUTCDate method 67
setUTCFullYear method 68
setUTCHours method 69
setUTCMilliseconds method 70
setUTCMinutes method 70
setUTCMonth method 71
setUTCSeconds method 72
setYear method 72
shift method 27
short-circuit evaluation 264
sign-propagating right shift (>>) operator 261,
263
sin method 122
slice method 28, 196
small method 197
sort method 29
source property 170
special operators 266
splice method 33
split method 198
SQRT1_2 property 124
SQRT2 property 124
sqrt method 123
square roots 123
statements 229–250
syntax conventions 229
strike method 201
String function 223
String object 173
string operators 266
298 Core JavaScript Reference
strings
blinking 179
bold 179
character position within 174, 180, 186
concatenating 266
converting from date 74
converting to floating point 220
creating from arrays 23
defining 173
fontsize of 178
length of 190
lowercase 175, 207
parsing 220
splitting into arrays 198
String object 173
sub method 202
substring method 204
substr method 203
sun object 210
sun property 150
sup method 206
switch statement 241
syntax conventions 229
T
tan method 125
test method 170
this keyword 274
throw statement 243
times
Date object 43
defining 43
minutes 51
toGMTString method 73
toLocaleString method 74
toLowerCase method 207
top-level properties and functions 211
toSource method
Array object 34
Boolean object 41
Date object 75
Function object 94
Number object 133
Object object 139
RegExp object 171
String object 207
toString method
Array object 35
Boolean object 41
built-in 140
Date object 76
Function object 95
JavaArray object 101
LiveConnect 285
Number object 134
Object object 140
RegExp object 171
String object 208
user-defined 140
toUpperCase method 208
toUTCString method 76
try...catch statement 246
typeof operator 275
U
unary negation (-) operator 260
undefined property 223
unescape function 224
unicode and 213
Unicode
charCodeAt method 181
escape function and 213
unescape function and 213
unshift method 36
unwatch method 143
Index 299
URLs
conventions used 12
escaping characters in 212
UTC method 77
UTC time, defined 44
V
valueOf method
Array object 37
Boolean object 42
Date object 78
Function object 96
Number object 135
Object object 143
RegExp object 172
String object 209
variables
declaring 248
initializing 248
syntax for declaring 248
var statement 248
versions of JavaScript 10
void operator 276
W
watch method 145
while loops
continuation of 233
syntax of 248
termination of 231
while statement 248
with statement 249
X
XOR (^) operator 261
Z
zero-fill right shift (>>>) operator 261, 263