Skip to content

Latest commit

 

History

History
151 lines (92 loc) · 5.4 KB

File metadata and controls

151 lines (92 loc) · 5.4 KB

Number

Number 생성자 함수

new 연산자와 함께 호출하여 Number 인스턴스를 생성할 수 있다.

Number 생성자 함수에 인수를 전달하지 않고 new 연산자와 함께 호출하면 [[NumberData]] 내부 슬롯에 0을 할당한 Number 래퍼 객체를 생성한다.

Number 생성자 함수의 인수로 숫자를 전달하면서 new 연산자와 함께 호출하면 [[NumberData]] 내부 슬롯에 인수로 전달받은 숫자를 할당한 Number 래퍼 객체를 생성한다.

const numObj1 = new Number();
console.log(numObj1); // Number {[[PrimitiveValue]]: 0}

const numObj2 = new Number(10);
console.log(numObj2); // Number {[[PrimitiveValue]]: 10}

인수로 숫자가 아닌 값을 전달하면 인수를 숫자로 강제 변환한 후 [[NumberData]] 내부 슬롯에 변환된 숫자를 할당한 Number 래퍼 객체를 생성한다.
인수를 숫자로 바꿀 수 없는 경우에는 NaN을 할당한다.

new 연산자를 사용하지 않고 Number 생성자 함수를 호출하면 숫자를 반환하기 때문에 이를 이용해 명시적으로 타입을 변환하기도 한다.

Number 프로퍼티

Number.EPSILON

1과 1보다 큰 숫자 중에서 가장 작은 숫자와의 차이와 같다.
자바스크립트가 표현할 수 있는 가장 작은 값이다.

부동소수점으로 인해 발생하는 오차를 해결하기 위해 사용.

function isEqual(a, b){
    // a와 b를 뺀 값의 절대값이 Number.EPSILON보다 작으면 같은 수로 인정한다.
    return Math.abs(a - b) < Number.EPSILON;
}

isEqual(0.1 + 0.2, 0.3); // true

Number.MAX_VALUE

자바스크립트에서 표현할 수 있는 가장 큰 양수 값.
이보다 더 큰 숫자는 Infinity다.

Number.MIN_VALUE

자바스크립트에서 표현할 수 있는 가장 작은 양수 값.
이보다 더 작은 숫자는 0이다.

Number.MAX_SAFE_INTEGER

자바스크립트에서 안전하게 표현할 수 있는 가장 큰 정수값. (9007199254740991)

Number.MIN_SAFE_INTEGER

자바스크립트에서 안전하게 표현할 수 있는 가장 작은 정수값. (-9007199254740991)

Number.POSITIVE_INFINITY

양의 무한대를 나타내는 숫자값 Infinity와 같음.

Number.NEGATIVE_INFINITY

음의 무한대를 나타내는 숫자값 -Infinity와 같음.

Number.NaN

숫자가 아님을 나타내는 숫자값으로 window.NaN과 같다.

Number 메서드

Number.isFinite

정적 메서드로 인수로 전달된 값이 정삭적인 유한수, 즉 Infinity 또는 -Infinity가 아닌지 검사하여
정상적인 유한수이면 true를 반환
무한수이면 false를 반환

빌트인 전역 함수 isFinite는 전달받은 인수를 숫자로 암묵적 타입 변환하여 검사를 수행하지만 Number.isFinite는 전달받은 인수를 숫자로 암묵적 타입 변환하지 않는다.

Number.isInteger

정적 메서드로 인수로 전달된 숫자값이 정수인지 검사하여 그 결과를 불리언 값으로 반환한다.
검사 전에 인수를 암묵전 타입 변환하지 않음.

Number.isNaN

정적 메서드로 인수로 전달된 값이 NaN인지 검사하여 그 결과를 불리언 값으로 반환한다.

빌트인 전역 함수 isNaN은 전달받은 인수를 숫자로 암묵적 타입 변환하여 검사를 수행하지만 Number.isNaN은 암묵적 타입 변환하지 않는다.

Number.isSafeInteger

정적 메서드로 인수로 전달된 숫자값이 안전한 정수인지 검사하여 그 결과를 불리언 값으로 반환한다.

안전한 정수값은 -(2^53 - 1)과 2^53 - 1 사이의 정수값이다.

검사전에 암묵적 타입 변환을 하지 않는다.

Number.prototype.toExponential

숫자를 지수 표기법으로 변환하여 문자열로 반환한다.

매우 크거나 작은 숫자를 표기할 때 주로 사용하며 e(Exponent) 앞에 있는 숫자에 10의 n승을 곱하는 형식으로 수를 나타낸다.

인수로 소수점 이하로 표현할 자리수를 전달할 수 있다.

(77.1234).toExponential(); // -> "7.71234e+1"
(77.1234).toExponential(4); // -> "7.7123e+1"

숫자 리터럴과 함께 Number 프로토타입 메서드를 사용하면 자바스크립트 엔진이 숫자 뒤의 .을 부동 소수점 숫자의 소수 구분 기호로 해석하기 때문에 에러가 발생한다.

77.toExponential(); // SyntaxError

Number.prototype.toFixed

숫자를 반올림하여 문자열로 반환한다.

반올림하는 소수점 이하 자리수를 나타내는 0~20 사이의 정수값을 인수로 전달 가능.
기본값은 0.

(12345.6789).toFixed(); // -> "12346"
(12345.6789).toFixed(1); // -> "12345.7"

Number.prototype.toPrecision

인수로 전달받은 전체 자릿수까지 유효하도록 나머지 자릿수를 반올림하여 문자열로 반환한다.
인수로 전달받은 전체 자릿수로 표현할 수 없는 경우 지수 표기법으로 결과를 반환.

전체 자릿수를 나타내는 0~21 사이의 정수값을 인수로 전달 가능
기본값은 0.

(12345.6789).toPrecision(); // -> "12345.6789"
(12345.6789).toPrecision(1); // -> "1e+4"
(12345.6789).toPrecision(6); // -> "12345.7"

Number.prototype.toString

숫자를 문자열로 변환하여 반환한다.

진법을 나타내는 2~36 사이의 정수값을 인수로 전달할 수 있다.
기본값은 10진법으로 지정.