4 분 소요

2022. 06. 02. 수업내용 정리

Math 객체


  • Math 객체

    수학에서 자주 사용하는 상수와 함수들을 미리 구현해 놓은 자바스크립트 표준 내장 객체입니다.

    다른 전역 객체와는 달리 생상자(constructor)가 존재하지 않습니다.

    따라서 따로 인스턴스를 생성하지 않아도 Math 객체의 모든 메소드나 프로퍼티를 바로 사용할 수 있습니다.



  • Math 메소드

    자바스크립트는 웹 페이지에서 수학적 작업을 손쉽게 할 수 있도록 다양한 Math 메소드를 제공하고 있습니다.

    가장 많이 사용되는 대표적인 Math 메소드는 다음과 같습니다.

    1. Math.min()
    2. Math.max()
    3. Math.random()
    4. Math.round()
    5. Math.floor()
    6. Math.ceil()
    7. Math.sin()


    대부분 Math 메소드는 웹브라우저마다 다른 결과값을 얻을 가능성이 높습니다.

    심지어 같은 자바스크립트 인터프리터라도 운영체제가 다르면 다른 결과값을 반환할 수 있습니다.

    따라서 아주 정확한 결과값이 필요한 작업에는 Math 메소드는 사용하지 않는 것이 좋습니다.



  • Math.min() 메소드

    인수로 전달받은 값 중에서 가장 작은 수를 반환합니다.

    인수가 전달되지 않으면 Infinity를 반환하며, 인수 중에 비교할 수 없는 값이 포함되어 있으면 NaN을 반환합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Math Method</title>
    </head>
      
    <body>
      
    	<h1>Math.min() 메소드</h1>
      
    	<script>
    		document.write(Math.min() + "<br>");								// Infinity
    		document.write(Math.min(1, 10, -100, -10, 1000, 0) + "<br>");		// -100
    		document.write(Math.min(1, 10, -100, -10, "-1000", 0) + "<br>");	// -1000
    		document.write(Math.min(1, 10, -100, -10, "문자열", 0));			// NaN
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    image-20220607224728385



  • Math.max() 메소드

    인수로 전달받은 값 중에서 가장 큰 수를 반환합니다.

    인수가 전달되지 않으면 -Infinity를 반환하며, 인수 중에 비교할 수 없는 값이 포함되어 있으면 NaN을 반환합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Math Method</title>
    </head>
      
    <body>
      
    	<h1>Math.max() 메소드</h1>
      
    	<script>
    		document.write(Math.max() + "<br>");								// -Infinity
    		document.write(Math.max(1, 10, -100, -10, 100, 0) + "<br>");		// 100
    		document.write(Math.max(1, 10, -100, -10, "1000", 0) + "<br>");		// 1000
    		document.write(Math.max(1, 10, -100, -10, "문자열", 0));			// NaN
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    image-20220607225030415{border:1px solid black}



  • Math.random() 메소드

    0보다 크거나 같고 1보다 작은 무작위 숫자(random number)를 반환합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Math Method</title>
    </head>
      
    <body>
      
    	<h1>Math.random() 메소드</h1>
      
    	<p>결과보기를 다시 누를 때마다 다른 랜덤 숫자가 생성됩니다.</p>
    	<script>
    		var min = 10, max = 20;
    		document.write(Math.random() + "<br>");				// [0, 1)
    		document.write(Math.random() * (max - min) + min);	// [min, max)
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    image-20220607230222785

    ★위의 예제에서 사용된 ‘[‘기호는 ‘크거나 같은’을 나타내며, ‘]’기호는 ‘작거나 같은’을 나타내는 기호입니다.
    또한, ‘(‘기호는 ‘보다 큰’을 나타내며, ‘)’기호는 ‘보다 작은’을 나타내는 기호입니다.



  • Math.round() 메소드

    인수로 전달받은 값을 소수점 첫 번째 자리에서 반올림하여 그 결괏값을 반환합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Math Method</title>
    </head>
      
    <body>
      
    	<h1>Math.round() 메소드</h1>
      
    	<script>
    		document.write(Math.round(10.49) + "<br>");		// 10
    		document.write(Math.round(10.5) + "<br>");		// 11
    		document.write(Math.round(-10.5) + "<br>");		// -10
    		document.write(Math.round(-10.51));				// -11
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    image-20220607230741601



  • Math.floor() 메소드

    인수로 전달받은 값과 같거나 작은 수 중에서 가장 큰 정수를 반환합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Math Method</title>
    </head>
      
    <body>
      
    	<h1>Math.floor() 메소드</h1>
      
    	<script>
    		document.write(Math.floor(10.95) + "<br>");		// 10
    		document.write(Math.floor(11.01) + "<br>");		// 11
    		document.write(Math.floor(-10.95) + "<br>");	// -11
    		document.write(Math.floor(-11.01));				// -12
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    image-20220607230941578



  • Math.ceil() 메소드

    인수로 전달받은 값과 같거나 큰 수 중에서 가장 작은 정수를 반환합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Math Method</title>
    </head>
      
    <body>
      
    	<h1>Math.ceil() 메소드</h1>
      
    	<script>
    		document.write(Math.ceil(10.95) + "<br>");		// 11
    		document.write(Math.ceil(11.01) + "<br>");		// 12
    		document.write(Math.ceil(11) + "<br>");			// 11
    		document.write(Math.ceil(-10.95) + "<br>");		// -10
    		document.write(Math.ceil(-11.01));				// -11
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    image-20220607231223890



  • Math.sin() 메소드

    인수로 전달받은 값의 사인(sine) 함숫값을 반환합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Math Method</title>
    </head>
      
    <body>
      
    	<h1>Math.sin() 메소드</h1>
      
    	<script>
    		document.write(Math.sin(0) + "<br>");	// 0
    		document.write(Math.sin(Math.PI / 2));	// 1
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    image-20220607231442735



    자바스크립트에서 제공하는 삼각 함수에 관한 모든 메소드는 각도의 단위로 라디안(radian)을 사용합니다.

    이때 라디안 단위와 60분법 단위를 서로 변환하기 위해서는 다음과 같은 공식을 사용합니다.

    문법
    라디안값 = 60분법값 * (Math.PI / 180)
    


    아래에 모든 Math 메소드, 프로퍼티를 표로 정리했습니다.

    자바스크립트 Math 메소드

    메소드 설명
    Math.min(x, y, …) 인수로 전달받은 값 중에서 가장 작은 수를 반환함.
    Math.max(x, y, …) 인수로 전달받은 값 중에서 가장 큰 수를 반환함.
    Math.random() 0보다 크거나 같고 1보다 작은 랜덤 숫자(random number)를 반환함.
    Math.round(x) x를 소수점 첫 번째 자리에서 반올림하여 그 결과를 반환함.
    Math.floor(x) x와 같거나 작은 수 중에서 가장 큰 정수를 반환함.
    Math.ceil(x) x와 같거나 큰 수 중에서 가장 작은 정수를 반환함.
    Math.abs(x) x의 절댓값을 반환함.
    Math.cbrt(x) x의 세제곱근을 반환함.
    Math.sqrt(x) x의 제곱근을 반환함.
    Math.clz32(x) x을 32비트 이진수로 변환한 후, 0이 아닌 비트의 개수를 반환함.
    Math.exp(x) ex 의 값을 반환함. (e : 오일러의 수)
    Math.expm1(x) 1 - ex 의 값을 반환함.
    Math.fround(x) x와 가장 근접한 32비트 부동 소수점 수(single precision float)를 반환함.
    Math.hypot(x, y, …) 인수로 전달받은 값들을 각각 제곱한 후 더한 총합의 제곱근을 반환함.
    Math.imul(x, y) 인수로 전달받은 두 값의 32비트 곱셈의 결과를 반환함.
    Math.log(x) x의 자연로그 값을 반환함. (ln x)
    Math.log1p(x) ln(1 + x)의 값을 반환함.
    Math.log10(x) x의 10을 밑으로 가지는 로그 값을 반환함.
    Math.log2(x) x의 2를 밑으로 가지는 로그 값을 반환함.
    Math.pow(x, y) x의 y승을 반환함.
    Math.sign(x) x의 부호 값을 반환함.
    Math.trunc(x) x의 모든 소수 부분을 삭제하고 정수 부분만을 반환함.
    Math.sin(x), Math.cos(x), Math.tan(x),Math.asin(x), Math.acos(x), Math.atan(x), Math.asinh(x), Math.acosh(x), Math.atanh(x), Math.atan2(x) x의 해당 삼각 함숫값을 반환함.

#### 자바스크립트 Math 프로퍼티

자바스크립트는 수학에서 사용하는 다양한 상수들을 Math 프로퍼티를 이용해 제공하고 있습니다.

프로퍼티 설명 대략값
Math.E 오일러의 수(Euler’s constant)라고 불리며, 자연로그(natural logarithms)의 밑(base) 값 2.718
Math.LN2 2의 자연로그 값 0.693
Math.LN10 10의 자연로그 값 2.303
Math.LOG2E 오일러 수(e)의 밑 값이 2인 로그 값 1.443
Math.LOG10E 오일러 수(e)의 밑 값이 10인 로그 값 0.434
Math.PI 원의 원주를 지름으로 나눈 비율(원주율) 값 3.14159
Math.SQRT1_2 2의 제곱근의 역수 값 0.707
Math.SQRT2 2의 제곱근 값 1.414

댓글남기기