Core object | |
Implemented in | Navigator 3.0, LiveWire 1.0 |
Array
object constructor:new Array(arrayLength);
new Array(element0, element1, ..., elementN);
billingMethod = new Array(5)When you create an array, all of its elements are initially null. The following code creates an array of 25 elements, then assigns values to the first three elements:
musicTypes = new Array(25)However, in Navigator 4.0, if you specify
musicTypes[0] = "R&B"
musicTypes[1] = "Blues"
musicTypes[2] = "Jazz"
LANGUAGE="JavaScript1.2"
in the <SCRIPT>
tag, using new Array(1)
creates a new array with a[0]=1
. 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()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:
colors[99] = "midnightblue"
myArray = new Array("Hello", myVar, 3.14159)In Navigator 2.0, you must index an array by its ordinal number, for example
document.forms[0]
. In Navigator 3.0 and later, you can index an array by either its ordinal number or by its name (if defined). For example, assume you define the following array:myArray = new Array("Wind","Rain","Fire")You can then refer to the first element of the array as
myArray[0]
or myArray["Wind"]
.
In Navigator 4.0, 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:
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()See also examples for
msgArray [0] = "Hello"
msgArray [99] = "world"
// The following statement is true,
// because defined msgArray [99] element.
if (msgArray .length == 100)
document.write("The length is 100.")
onError
.a = new Array(4)This example displays the following results:
for (i=0; i < 4; i++) {
a[i] = new Array(4)
for (j=0; j < 4; j++) {
a[i][j] = "["+i+","+j+"]"
}
}
for (i=0; i < 4; i++) {
str = "Row "+i+":"
for (j=0; j < 4; j++) {
str += a[i][j]
}
document.write(str,"<p>")
}
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]
Image
Property of |
Array
|
Static | |
Implemented in | Navigator 4.0, Netscape Server 3.0 |
Property of |
Array
|
Static | |
Implemented in | Navigator 4.0, Netscape Server 3.0 |
length
property to truncate an array at any time. You cannot extend an array; for example, if you set length to 3 when it is currently 2, the array will still contain only 2 elements.
Property of |
Array
|
Implemented in | Navigator 3.0, LiveWire 1.0 |
getChoice
function uses the length
property to iterate over every element in the musicType
array. musicType
is a select element on the musicForm
form.function getChoice() {The following example shortens the array
for (var i = 0; i < document.musicForm.musicType.length; i++) {
if (document.musicForm.musicType.options[i].selected == true) {
return document.musicForm.musicType.options[i].text
}
}
}
statesUS
to a length of 50 if the current length is greater than 50.if (statesUS.length > 50) {
statesUS.length=50
alert("The U.S. has only 50 states. New length is " + statesUS.length)
}
Function.prototype
.
Property of |
Array
|
Implemented in | Navigator 3.0, LiveWire 1.0 |
Method of |
Array
|
Implemented in | Navigator 4.0, Netscape Server 3.0 |
concat(arrayName2)
arrayName2 | Name of the array to concatenate to this array. |
concat
does not alter the original arrays, but returns a "one level deep" copy that contains copies of the same elements combined from the original arrays. Elements of the original arrays are copied into the new array as follows: concat
copies object references into the new array. Both the original and new array refer to the same object. If a referenced object changes, the changes are visible to both the new and original arrays. String
and Number
objects)-- concat
copies strings and numbers into the new array. Changes to the string or number in one array does not affect the other arrays.
Method of |
Array
|
Implemented in | Navigator 3.0, LiveWire 1.0 |
join(separator)
separator | Specifies a string to separate each element of the array. The separator is converted to a string if necessary. If omitted, the array elements are separated with a comma. |
a
with three elements, then joins the array three times: using the default separator, then a comma and a space, and then a plus.a = new Array("Wind","Rain","Fire")This code produces the following output:
document.write(a.join() +"<BR>")
document.write(a.join(", ") +"<BR>")
document.write(a.join(" + ") +"<BR>")
Wind,Rain,Fire
Wind, Rain, Fire
Wind + Rain + Fire
Array.reverse
Method of |
Array
|
Implemented in | Navigator 4.0, Netscape Server 3.0 |
pop()
myFish
array before and after removing its last element. It also displays the removed element:myFish = ["angel", "clown", "mandarin", "surgeon"];This example displays the following:
document.writeln("myFish before: " + myFish);
popped = myFish.pop();
document.writeln("myFish after: " + myFish);
document.writeln("popped this element: " + popped);
myFish before: ["angel", "clown", "mandarin", "surgeon"]
myFish after: ["angel", "clown", "mandarin"]
popped this element: surgeon
push
, shift
, unshift
Method of |
Array
|
Implemented in | Navigator 4.0, Netscape Server 3.0 |
push(elt1, ..., eltN)
elt1, ..., eltN | The elements to add to the end of the array. |
push
method is analogous to the push function in Perl 4. Note that this behavior is different in Perl 5.myFish
array before and after adding elements to its end. It also displays the last element added:myFish = ["angel", "clown"];This example displays the following:
document.writeln("myFish before: " + myFish);
pushed = myFish.push("drum", "lion");
document.writeln("myFish after: " + myFish);
document.writeln("pushed this element last: " + pushed);
myFish before: ["angel", "clown"]
myFish after: ["angel", "clown", "drum", "lion"]
pushed this element last: lion
pop
, shift
, unshift
Method of |
Array
|
Implemented in | Navigator 3.0, LiveWire 1.0 |
reverse()
reverse
method transposes the elements of the calling array object.myArray
, containing three elements, then reverses the array.myArray = new Array("one", "two", "three")This code changes
myArray.reverse()
myArray
so that:myArray[0]
is "three"
myArray[1]
is "two"
myArray[2]
is "one"
Array.join
, Array.sort
Method of |
Array
|
Implemented in | Navigator 4.0, Netscape Server 3.0 |
shift()
myFish
array before and after removing its first element. It also displays the removed element:myFish = ["angel", "clown", "mandarin", "surgeon"];This example displays the following:
document.writeln("myFish before: " + myFish);
shifted = myFish.shift();
document.writeln("myFish after: " + myFish);
document.writeln("Removed this element: " + shifted);
myFish before: ["angel", "clown", "mandarin", "surgeon"]
myFish after: ["clown", "mandarin", "surgeon"]
Removed this element: angel
pop
, push
, unshift
Method of |
Array
|
Implemented in | Navigator 4.0, Netscape Server 3.0 |
slice(begin,end)
slice
does not alter the original array, but returns a new "one level deep" copy that contains copies of the elements sliced from the original array. Elements of the original array are copied into the new array as follows:
Object references (and not the actual object) -- slice
copies object references into the new array. Both the original and new array refer to the same object. If a referenced object changes, the changes are visible to both the new and original arrays.
Strings and numbers (not String
and Number
objects)-- slice
copies strings and numbers into the new array. Changes to the string or number in one array does not affect the other array.
If a new element is added to either array, the other array is not affected.
slice
creates a new array, newCar
, from myCar
. Both include a reference to the object myHonda
. When the color of myHonda
is changed to purple
, both arrays reflect the change. <SCRIPT LANGUAGE="JavaScript1.2">
//Using slice, create newCar from myCar.
myHonda = {color:"red",wheels:4,engine:{cylinders:4,size:2.2}}
myCar = [myHonda, 2, "cherry condition", "purchased 1997"]
newCar = myCar.slice(0,2)
//Write the values of myCar, newCar, and the color of myHonda
// referenced from both arrays.
document.write("myCar = " + myCar + "<BR>")
document.write("newCar = " + newCar + "<BR>")
document.write("myCar[0].color = " + myCar[0].color + "<BR>")
document.write("newCar[0].color = " + newCar[0].color + "<BR><BR>")
//Change the color of myHonda.
myHonda.color = "purple"
document.write("The new color of my Honda is " + myHonda.color + "<BR><BR>")
//Write the color of myHonda referenced from both arrays.
document.write("myCar[0].color = " + myCar[0].color + "<BR>")
document.write("newCar[0].color = " + newCar[0].color + "<BR>")
</SCRIPT>This script writes:
myCar = [{color:"red", wheels:4, engine:{cylinders:4, size:2.2}}, 2,
"cherry condition", "purchased 1997"]
newCar = [{color:"red", wheels:4, engine:{cylinders:4, size:2.2}}, 2]
myCar[0].color = red newCar[0].color = red
The new color of my Honda is purple
myCar[0].color = purple
newCar[0].color = purple
Method of |
Array
|
Implemented in | Navigator 4.0, Netscape Server 3.0 |
splice(index, howMany, newElt1, ..., newEltN)
If howMany
is 1, this method returns the single element that it removes. If howMany
is more than 1, the method returns an array containing the removed elements.
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"]
Method of |
Array
|
Implemented in |
Navigator 3.0, LiveWire 1.0 Navigator 4.0: modified behavior. |
sort(compareFunction)
compareFunction | Specifies a function that defines the sort order. If omitted, the array is sorted lexicographically (in dictionary order) according to the string conversion of each element. |
compareFunction
is not supplied, elements are sorted by converting them to strings and comparing strings in lexicographic ("dictionary" or "telephone book," not numerical) order. For example, "80" comes before "9" in lexicographic order, but in a numeric sort 9 comes before 80.
If compareFunction
is supplied, the array elements are sorted according to the return value of the compare function. If a and b are two elements being compared, then:
compareFunction(a, b)
is less than 0, sort b
to a lower index than a
.compareFunction(a, b)
returns 0, leave a
and b
unchanged with respect to each other, but sorted with respect to all different elements.compareFunction(a, b)
is greater than 0, sort b
to a higher index than a
.function compare(a, b) {To compare numbers instead of strings, the compare function can simply subtract b from a:
if (a is less than b by some ordering criterion)
return -1
if (a is greater than b by the ordering criterion)
return 1
// a must be equal to b
return 0
}
function compareNumbers(a, b) {JavaScript uses a stable sort: the index partial order of a and b does not change if a and b are equal. If a's index was less than b's before sorting, it will be after sorting, no matter how a and b move due to sorting.
return a - b
}
The behavior of the sort
method changed between Navigator 3.0 and
Navigator 4.0.
In Navigator 3.0, on some platforms, the sort
method does not work. This method works on all platforms for Navigator 4.0.
<SCRIPT>
a = new Array();
a[0] = "Ant";
a[5] = "Zebra";
function writeArray(x) {
for (i = 0; i < x.length; i++) {
document.write(x[i]);
if (i < x.length-1) document.write(", ");
}
}
writeArray(a);In Navigator 3.0, JavaScript prints:
a.sort();
document.write("<BR><BR>");
writeArray(a);
</SCRIPT>
ant, null, null, null, null, zebraIn Navigator 4.0, JavaScript prints:
ant, null, null, null, null, zebra
ant, undefined, undefined, undefined, undefined, zebra
ant, zebra, undefined, undefined, undefined, undefined
<SCRIPT>
stringArray = new Array("Blue","Humpback","Beluga")
numericStringArray = new Array("80","9","700")
numberArray = new Array(40,1,5,200)
mixedNumericArray = new Array("80","9","700",40,1,5,200)
function compareNumbers(a, b) {
return a - b
}
document.write("<B>stringArray:</B> " + stringArray.join() +"<BR>")
document.write("<B>Sorted:</B> " + stringArray.sort() +"<P>")
document.write("<B>numberArray:</B> " + numberArray.join() +"<BR>")
document.write("<B>Sorted without a compare function:</B> " + numberArray.sort() +"<BR>")
document.write("<B>Sorted with compareNumbers:</B> " + numberArray.sort(compareNumbers) +"<P>")
document.write("<B>numericStringArray:</B> " + numericStringArray.join() +"<BR>")
document.write("<B>Sorted without a compare function:</B> " + numericStringArray.sort() +"<BR>")
document.write("<B>Sorted with compareNumbers:</B> " + numericStringArray.sort(compareNumbers) +"<P>")
document.write("<B>mixedNumericArray:</B> " + mixedNumericArray.join() +"<BR>")This example produces the following output. As the output shows, when a compare function is used, numbers sort correctly whether they are numbers or numeric strings.
document.write("<B>Sorted without a compare function:</B> " + mixedNumericArray.sort() +"<BR>")
document.write("<B>Sorted with compareNumbers:</B> " + mixedNumericArray.sort(compareNumbers) +"<BR>")
</SCRIPT>
stringArray: Blue,Humpback,Beluga
Sorted: Beluga,Blue,Humpback
numberArray: 40,1,5,200
Sorted without a compare function: 1,200,40,5
Sorted with compareNumbers: 1,5,40,200
numericStringArray: 80,9,700
Sorted without a compare function: 700,80,9
Sorted with compareNumbers: 9,80,700
mixedNumericArray: 80,9,700,40,1,5,200
Sorted without a compare function: 1,200,40,5,700,80,9
Sorted with compareNumbers: 1,5,9,40,80,200,700
Array.join
, Array.reverse
Method of |
Array
|
Implemented in | Navigator 3.0, LiveWire 1.0 |
toString()
toString
method that is automatically called when it is to be represented as a text value or when an object is referred to in a string concatenation.
You can use toString
within your own code to convert an object into a string, and you can create your own function to be called in place of the default toString
method.
For Array
objects, the built-in toString
method joins the array and returns one string containing each array element separated by commas. For example, the following code creates an array and uses toString
to convert the array to a string while writing output.
var monthNames = new Array("Jan","Feb","Mar","Apr")The output is as follows:
document.write("monthNames.toString() is " + monthNames.toString())
monthNames.toString() is Jan,Feb,Mar,AprFor information on defining your own
toString
method, see the Object.toString
method.
Method of |
Array
|
Implemented in | Navigator 4.0, Netscape Server 3.0 |
arrayName.unshift(elt1,..., eltN)
elt1,...,eltN | The elements to add to the front of the array. |
myFish
array before and after adding elements to it.myFish = ["angel", "clown"];This example displays the following:
document.writeln("myFish before: " + myFish);
unshifted = myFish.unshift("drum", "lion");
document.writeln("myFish after: " + myFish);
document.writeln("New length: " + unshifted);
myFish before: ["angel", "clown"]
myFish after: ["drum", "lion", "angel", "clown"]
New length: 4
pop
, push
, shift
Last Updated: 10/31/97 16:00:33