Previous Contents Index Next |

Core JavaScript Reference 1.5 |

Lets you work with numeric values. The Number object is an object wrapper for primitive numeric values.

JavaScript 1.2: modified behavior of Number constructor.

JavaScript 1.3: added toSource method.

JavaScript 1.5, NES 6.0: added toExponential, toFixed, and toPrecision methods.

Created by

The Number constructor:

value

Description

The primary uses for the Number object are:The properties of Number are properties of the class itself, not of individual Number objects.

- 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.
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,

You can convert any object to a number using the top-level Number function.

Property

Descriptionconstructor

MAX_VALUE

MIN_VALUE

NaN

NEGATIVE_INFINITY

Special value representing negative infinity; returned on overflow.

POSITIVE_INFINITY

prototype

Method

DescriptiontoExponential

Returns a string representing the number in exponential notation.

toFixed

Returns a string representing the number in fixed-point notation.

toPrecision

Returns a string representing the number to a specified precision in fixed-point notation.

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.

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;

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";

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.

The maximum numeric value representable in JavaScript.

Description

The MAX_VALUE property has a value of approximately 1.79E+308. Values larger than MAX_VALUE are represented as "Infinity".Because MAX_VALUE is a static property of Number, you always use it as Number.MAX_VALUE, rather than as a property of a Number object you created.

Examples

The following code multiplies two numeric values. If the result is less than or equal to MAX_VALUE, the func1 function is called; otherwise, the func2 function is called.if (num1 * num2 <= Number.MAX_VALUE)

func1()

else

func2()

The smallest positive numeric value representable in JavaScript.

Description

The MIN_VALUE property is the number closest to 0, not the most negative number, that JavaScript can represent.MIN_VALUE has a value of approximately 5e-324. Values smaller than MIN_VALUE ("underflow values") are converted to 0.

Because MIN_VALUE is a static property of Number, you always use it as Number.MIN_VALUE, rather than as a property of a Number object you created.

Examples

The following code divides two numeric values. If the result is greater than or equal to MIN_VALUE, the func1 function is called; otherwise, the func2 function is called.if (num1 / num2 >= Number.MIN_VALUE)

func1()

else

func2()

A special value representing Not-A-Number. This value is represented as the unquoted literal NaN.

Description

JavaScript prints the value Number.NaN as 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

isNaNfunction instead.You might use the NaN property to indicate an error condition for a function that should return a valid number.

Examples

In the following example, if month has a value greater than 12, it is assigned NaN, and a message is displayed indicating valid values.var month = 13

if (month < 1 || month > 12) {

month = Number.NaN

alert("Month must be between 1 and 12.")

}

See also

NaN, isNaN, parseFloat, parseInt

A special numeric value representing negative infinity. This value is represented as the unquoted literal "-Infinity".

Description

This value behaves slightly differently than mathematical infinity:Because NEGATIVE_INFINITY is a static property of Number, you always use it as Number.NEGATIVE_INFINITY, rather than as a property of a Number object you created.

- Any positive value, including POSITIVE_INFINITY, multiplied by NEGATIVE_INFINITY is NEGATIVE_INFINITY.
- Any negative value, including NEGATIVE_INFINITY, multiplied by NEGATIVE_INFINITY is POSITIVE_INFINITY.
- Zero multiplied by NEGATIVE_INFINITY is NaN.
- NaN multiplied by NEGATIVE_INFINITY is NaN.
- NEGATIVE_INFINITY, divided by any negative value except NEGATIVE_INFINITY, is POSITIVE_INFINITY.
- NEGATIVE_INFINITY, divided by any positive value except POSITIVE_INFINITY, is NEGATIVE_INFINITY.
- NEGATIVE_INFINITY, divided by either NEGATIVE_INFINITY or POSITIVE_INFINITY, is NaN.
- Any number divided by NEGATIVE_INFINITY is Zero.

Examples

In the following example, the variable smallNumber is assigned a value that is smaller than the minimum value. When the if statement executes, smallNumber has the value "-Infinity", so the func1 function is called.var smallNumber = -Number.MAX_VALUE*10

if (smallNumber == Number.NEGATIVE_INFINITY)

func1()

else

func2()

A special numeric value representing infinity. This value is represented as the unquoted literal "Infinity".

Description

This value behaves slightly differently than mathematical infinity:Because POSITIVE_INFINITY is a static property of Number, you always use it as Number.POSITIVE_INFINITY, rather than as a property of a Number object you created.

- Any positive value, including POSITIVE_INFINITY, multiplied by POSITIVE_INFINITY is POSITIVE_INFINITY.
- Any negative value, including NEGATIVE_INFINITY, multiplied by POSITIVE_INFINITY is NEGATIVE_INFINITY.
- Zero multiplied by POSITIVE_INFINITY is NaN.
- NaN multiplied by POSITIVE_INFINITY is NaN.
- POSITIVE_INFINITY, divided by any negative value except NEGATIVE_INFINITY, is NEGATIVE_INFINITY.
- POSITIVE_INFINITY, divided by any positive value except POSITIVE_INFINITY, is POSITIVE_INFINITY.
- POSITIVE_INFINITY, divided by either NEGATIVE_INFINITY or POSITIVE_INFINITY, is NaN.
- Any number divided by POSITIVE_INFINITY is Zero.

Examples

In the following example, the variable bigNumber is assigned a value that is larger than the maximum value. When the if statement executes, bigNumber has the value "Infinity", so the func1 function is called.var bigNumber = Number.MAX_VALUE * 10

if (bigNumber == Number.POSITIVE_INFINITY)

func1()

else

func2()

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.

Returns a string representing the Number object in exponential notation.

Syntax

toExponential([fractionDigits])

fractionDigits

An integer specifying the number of digits after the decimal point. Defaults to as many digits as necessary to specify the number.

Description

The Number.prototype.toExponential method returns a string representing a Number object in exponential notation with one digit before the decimal point, rounded tofractionDigitsdigits after the decimal point. If thefractionDigitsargument is omitted, the number of digits after the decimal point defaults to the number of digits necessary to represent the value uniquely.If you use the toExponential method for a numeric literal and the numeric literal has no exponent and no decimal point, leave a space before the dot that precedes the method call to prevent the dot from being interpreted as a decimal point.

If a number has more digits that requested by the

fractionDigitsparameter, the number is rounded to the nearest number represented byfractionDigitsdigits. See the discussion of rounding in the description of the toFixed method on page 129, which also applies to toExponential.

Examples

var num=77.1234

alert("num.toExponential() is " + num.toExponential()) //displays 7.71234e+1

alert("num.toExponential(4) is " + num.toExponential(4)) //displays 7.7123e+1

alert("num.toExponential(2) is " + num.toExponential(2)) //displays 7.71e+1

alert("77.1234.toExponential() is " + 77.1234.toExponential())

//displays 7.71234e+1

alert("77 .toExponential() is " + 77 .toExponential()) //displays 7.7e+1

See also

toFixed, toPrecision, toString

Returns a string representing the Number object in fixed-point notation.

Syntax

toFixed([fractionDigits])

fractionDigits

An integer specifying the number of digits after the decimal point. Defaults to zero.

Description

The Number.prototype.toFixed method returns a string representing a Number object in fixed-point notation, rounded to the number of digits after the decimal point specified byfractionDigits.The output of toFixed may be more precise than toString for some values, because toString outputs only enough significant digits to distinguish the number from adjacent number values.

If a number has more digits that requested by the

fractionDigitsparameter, the number is rounded to the nearest number represented byfractionDigitsdigits. If the number is exactly halfway between two representable numbers, it is rounded away from zero (up if it is positive, down if it is negative). Thus:Given this convention, one might expect 0.045.toFixed(2) to return "0.05", but it returns "0.04". This is because of the way computers represent IEEE 754 floating-point numbers. The IEEE 754 standard uses binary fractions (fractions of 0's and 1's after the dot). Just as some numbers, such as 1/3, are not representable precisely as decimal fractions, other numbers, such as 0.045, are not precisely representable as binary fractions. The IEEE 754 standard dictates that 0.045 be approximated to 0.04499999999999999833466546306226518936455249786376953125, which is precisely representable as a binary fraction. This approximation is closer to 0.04 than to 0.05, so 0.045.toFixed(2) returns "0.04".

Examples

var num=10.1234

alert("num.toFixed() is " + num.toFixed()) //displays 10

alert("num.toFixed(4) is " + num.toFixed(4)) //displays 10.1234 alert("num.toFixed(2) is " + num.toFixed(2)) //displays 10.12

See also

toExponential, toPrecision, toString

Returns a string representing the Number object to the specified precision.

Syntax

toPrecision([precision])

precision

An integer specifying the number of digits after the decimal point.

Description

The Number.prototype.toPrecision method returns a string representing a Number object in fixed-point or exponential notation rounded toprecisionsignificant digits.If you use the toPrecision method for a numeric literal and the numeric literal has no exponent and no decimal point, leave a space before the dot that precedes the method call to prevent the dot from being interpreted as a decimal point.

If the

precisionargument is omitted, behaves as Number.prototype.toString.If a number has more digits that requested by the

precisionparameter, the number is rounded to the nearest number represented byprecisiondigits. See the discussion of rounding in the description of the toFixed method on page 129, which also applies to toPrecision.

Examples

var num=5.123456

alert("num.toPrecision() is " + num.toPrecision()) //displays 5.123456

alert("num.toPrecision(4) is " + num.toPrecision(4)) //displays 5.123

alert("num.toPrecision(2) is " + num.toPrecision(2)) //displays 5.1

alert("num.toPrecision(2) is " + num.toPrecision(1)) //displays 5

alert("num.toPrecision(2) is " + num.toPrecision(1)) //displays 5

alert("1250 .toPrecision() is " + 1250 .toPrecision(2))

//displays 1.3e+3

alert("1250 .toPrecision(5) is " + 1250 .toPrecision(5))

//displays 1250.0

See also

toExponential, toFixed, toString

Returns a string representing the source code of the object.

Description

The toSource method returns the following values:This method is usually called internally by JavaScript and not explicitly in code.

- For the built-in Number object, toSource returns the following string indicating that the source code is not available:
- For instances of Number, toSource returns a string representing the source code.

See also

Object.toSource

Returns a string representing the specified Number object.

Syntax

toString()

toString([radix])

radix

An integer between 2 and 36 specifying the base to use for representing numeric values.

Description

The Number object overrides the toString method of the Object object; it does not inherit Object.toString. For Number objects, the toString method returns a string representation of the object.JavaScript calls the toString method automatically when a number is to be represented as a text value or when a number is referred to in a string concatenation.

If you use the toString method for a numeric literal and the numeric literal has no exponent and no decimal point, leave a space before the dot that precedes the method call to prevent the dot from being interpreted as a decimal point.

For Number objects and values, the built-in toString method returns the string representing the value of the number.

var howMany=10;

alert("howMany.toString() is " + howMany.toString())

alert("45 .toString() is " + 45 .toString())

See also

toExponential, toFixed, toPrecision

Returns the primitive value of a Number object.

Description

The valueOf method of Number returns the primitive value of a Number object as a number data type.This method is usually called internally by JavaScript and not explicitly in code.

Examples

x = new Number();

alert(x.valueOf()) //displays 0

See also

Object.valueOf

PreviousContentsIndexNext

Copyright © 2000 Netscape Communications Corp. All rights reserved.

Last Updated **September 28, 2000**