4 분 소요

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

객체 프로퍼티와 메소드


  • 객체 프로퍼티

    모든 자바스크립트 객체는 Object 객체와 Object.prototype 객체의 모든 프로퍼티를 상속받습니다.

    prototype 프로퍼티를 이용하면 현재 존재하는 프로토타입에 새로운 프로퍼티나 메소드를 손쉽게 추가할 수 있습니다.


  • 객체 메소드

    모든 자바스크립트 객체는 Object 객체와 Object.prototype 객체의 모든 프로퍼티와 메소드를 상속받습니다.

    자주 사용하는 대표적인 객체 메소드는 다음과 같습니다.


    1. hasOwnProperty()
    2. propertyIsEnumerable()
    3. isPrototypeOf()
    4. isExtensible()
    5. toString()
    6. valueOf()



  • hasOwnProperty() 메소드

    hasOwnProperty() 메소드는 특정 프로퍼티가 해당 객체에 존재하는지를 검사합니다.

    해당 객체에서 직접 선언된 프로퍼티만을 검사하며, 같은 이름의 프로퍼티라도 상속받은 프로퍼티는 false값을 반환합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Object Method</title>
    </head>
      
    <body>
      
    	<h1>객체의 hasOwnProperty() 메소드</h1>
      
    	<script>
    		function Dog(color, name, age, family) {
    			this.color = color;
    			this.name = name;
    			this.age = age;
    			this.family = family;
    			this.breed = function() { return this.color + " " + this.family; }
    		}
    		var myDog = new Dog("검정색", "", 3, "불독");
      
    		document.write(myDog.hasOwnProperty("color") + "<br>");	// true
    		document.write(myDog.hasOwnProperty("breed") + "<br>");	// true
    		document.write(myDog.hasOwnProperty("class"));			// 상속받은 속성이므로 false를 반환함.
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    객체예시15



  • propertyIsEunmerable() 메소드

    특정 프로퍼티가 해당 객체에 존재하고, 열거할 수 있는 프로퍼티인지를 검사합니다.

    즉, 이 메소드는 hasOwnProperty() 메소드의 결과가 true이면서, 동시에 열거할 수 있는 프로퍼티인지를 검사합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Object Method</title>
    </head>
      
    <body>
      
    	<h1>객체의 propertyIsEnumerable() 메소드</h1>
      
    	<script>
    		function Dog(color, name, age) {
    			this.color = color;
    			this.name = name;
    			this.age = age;
    		}
    		var myDog = new Dog("흰색", "마루", 1);
    		// color 프로퍼티의 enumerable 속성을 false로 설정함.
    		Object.defineProperty(myDog, 'color', { enumerable : false} );
      		
    		document.write(myDog.propertyIsEnumerable("color") + "<br>");	// false
    		document.write(myDog.propertyIsEnumerable("name") + "<br>");	// true
    		document.write(myDog.propertyIsEnumerable("age"));				// true
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    객체예시16

    ★열거할 수 있는 프로퍼티란 내부적으로 enumerable 플래그가 true로 설정된 프로퍼티를 의미합니다.
    이러한 프로퍼티들은 for / in 문으로 접근할 수 있게 됩니다.

    ★Object.defineProperty() 메소드는 ECMAScript 5부터 추가된 객체에 프로퍼티를 추가해주는 메소드입니다.
    이때 추가하는 프로퍼티의 속성까지도 설정할 수 있습니다.

  • isPrototypeOf() 메소드

    특정 개체의 프로토타입 체인에 현재 객체가 존재하는지를 검사합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Object Method</title>
    </head>
      
    <body>
      
    	<h1>객체의 isPrototypeOf() 메소드</h1>
      
    	<script>
    		var day = new Date(); 	// Date 객체를 생성함.
      		
    		// 객체 day의 프로토타입이 Date.prototype인지를 검사함.
    		document.write(Date.prototype.isPrototypeOf(day) + "<br>");	// true
    		document.write(Date.prototype.isPrototypeOf(new String()));	// false
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    객체예시17



  • isExtensible() 메소드

    객체에 새로운 프로퍼티를 추가할 수 있는지 여부를 반환합니다.

    자바스크립트에서 모든 객체는 기본적으로 새로운 프로퍼티를 추가할 수 있으나 preventExtensions()메소드를 사용하여 해당 객체에

    새로운 프로퍼티를 추가할 수 없도록 설정할 수 있습니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Object Method</title>
    </head>
      
    <body>
      
    	<h1>객체의 isExtensible() 메소드</h1>
      
    	<script>
    		var day = new Date(); 	// Date 객체를 생성함.
    		// 객체 day에 새로운 프로퍼티를 추가할 수 있는지 검사함.
    		document.write(Object.isExtensible(day) + "<br>");	// true
      
    		// 해당 객체에 새로운 프로퍼티를 추가할 수 없도록 설정함.
    		var myDay = Object.preventExtensions(day);
    		document.write(Object.isExtensible(day));			// false
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    객체예시18



    toString() 메소드

    이 메소드를 호출한 객체의 값을 문자열로 반환합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Object Method</title>
    </head>
      
    <body>
      
    	<h1>객체의 toString() 메소드</h1>
      
    	<script>
    		var arr = [10, "문자열", true];		// 배열
    		var bool = false;					// 불리언
    		function func() {					// 함수
    			return 0;
    		}
      
    		document.write(arr.toString() + "<br>");	// 10,문자열,true.. toString 메소드는 어떠한 인수도 전달받지 않음.
    		document.write(bool.toString() + "<br>");	// false
    		document.write(func.toString());			// 함수의 소스 코드가 전부 문자열로 반환됨.
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    객체예시19



  • valueOf() 메소드

    특정 객체의 원시 타입(primitive type) 값을 반환합니다.

    자바스크립트에서는 원시 타입의 값이 있는 곳에 객체가 사용되면, 내부적으로 이 메소드를 호출하여 처리합니다.

    만약 어떤 객체가 원시 타입의 값을 가지고 있지 않다면, 이 메소드느느 객체 자신을 반환합니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Object Method</title>
    </head>
      
    <body>
      
    	<h1>객체의 valueOf() 메소드</h1>
      
    	<script>
    		function func(n) {
    			this.number = n;
    		}
      
    		myFunc = new func(4);
    		document.write(myFunc + 5);		// ①
      
    		func.prototype.valueOf = function() {
    			return this.number;
    		}
    		document.write("<br><br>")
    		document.write(myFunc + 5);		// ②
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    객체예시20

    위의 예제 ① 부분에서는 산술 연산을 위해 number 타입의 값을 기대하는 곳에 myFunc 객체가 사용됩니다.

    따라서 자바스크립트는 내부적으로 해당 객체의 valueOf() 메소드를 호출합니다.

    하지만 이 객체의 valueOf() 메소드는 아직 정의되지 않았으므로, 해당 객체 자신을 반환하게 됩니다.

    따라서 산술 연산이 아닌 문자열 결합 연산이 수행됩니다.

    그 후, 예제에서는 prototype 프로퍼티를 이용하여 valueOf() 메소드를 정의합니다.

    따라서 ② 부분에서는 내부적으로 호출된 valueOf() 메소드가 해당 객체의 number 프로퍼티 값을 반환합니다.

    따라서 정상적으로 산술 연산이 수행됩니다.



  • getter 와 setter 메소드의 정의

    getter와 setter 메소드로 정의된 프로퍼티는 단순한 값을 지닌 데이터 프로퍼티와 달리 접근자 프로퍼티라고 부릅니다.


    getter 메소드는 특정 프로퍼티의 값을 받아오기 위한 메소드입니다.

    자바스크립트는 객체의 프로퍼티 값에 접근할 때 getter 메소드에 아무런 인수를 전달하지 않고 호출합니다.


    setter 메소드는 특정 프로퍼티의 값을 설정하기 위한 메소드입니다.

    자바스크립트는 객체의 프로퍼티 값을 변경할 때 setter 메소드에 대입하고자 하는 값을 인수로 전달하여 호출합니다.


    다음 예제는 getter 메소드를 정의하는 예제입니다.

    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Object Method</title>
    </head>
      
    <body>
      
    	<h1>getter 메소드</h1>
      
    	<script>
    		var gildong = { age: 18 };
    		document.write(gildong.age + "<br>");	// 18
      
    		Object.defineProperty(gildong, "americanAge", { get: function() { return this.age - 1; } });
    		document.write(gildong.americanAge);	// 17
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    객체예시21



    위의 예제에서는 gildong 객체에 americanAge라는 프로퍼티를 추가할 때 get 키워드를 사용하여 getter 메소드를 정의하고 있습니다.

    따라서 해당 프로퍼티를 참조하려고 할 때는 내부적으로 미리 정의한 getter 메소드가 자동으로 호출될 것입니다.


    <!DOCTYPE html>
    <html lang="ko">
      
    <head>
    	<meta charset="UTF-8">
    	<title>JavaScript Object Method</title>
    </head>
      
    <body>
      
    	<h1>setter 메소드</h1>
      
    	<script>
    		var gildong = { age: 18 };
      
    		gildong.age = 20;
    		document.write(gildong.age + "<br>");	// 20
      
    		Object.defineProperty(gildong, "changeAge", { set: function(n) { this.age = this.age - n; } });
    		gildong.changeAge = 5;
    		document.write(gildong.age);			// 15
    	</script>
      	
    </body>
      
    </html>
    

    웹페이지 화면 ▼

    객체예시22

    위의 예제에서는 gildong 객체에 changeAge라는 프로퍼티를 추가할 때 set 키워드를 사용하여 setter 메소드를 정의하고 있습니다.

    따라서 해당 프로퍼티의 값을 변경하려고 할 때는 내부적으로 미리 정의한 setter 메소드가 자동으로 호출될 것입니다.

댓글남기기