> 웹 프론트엔드 > JS 튜토리얼 > JavaScript 객체의 생성자를 어떻게 정의합니까?

JavaScript 객체의 생성자를 어떻게 정의합니까?

Barbara Streisand
풀어 주다: 2024-11-05 01:02:02
원래의
859명이 탐색했습니다.

How do you define constructors for JavaScript objects?

JavaScript 객체의 생성자

JavaScript는 Java 또는 C와 같은 다른 객체 지향 언어처럼 전통적인 의미의 클래스를 지원하지 않습니다. 그러나 프로토타입을 사용하여 객체에 대한 생성자를 정의하는 고유한 메커니즘을 제공합니다.

프로토타입 사용:

JavaScript 객체에는 메서드를 추가하는 데 사용할 수 있는 프로토타입 속성이 있으며 해당 개체의 모든 인스턴스에 대한 속성입니다. 프로토타입을 사용하여 생성자를 정의하려면 함수를 생성하여 객체의 프로토타입에 할당합니다.

<code class="javascript">function Box(color) { // Constructor
    this.color = color;
}

Box.prototype.getColor = function() {
    return this.color;
};</code>
로그인 후 복사

이 생성자는 색상 인수를 가져와 객체의 color 속성에 저장합니다. 또한 Box 개체의 모든 인스턴스에서 액세스할 수 있는 getColor 메서드를 프로토타입에 추가합니다.

개인 속성 숨기기:

JavaScript에는 true가 없습니다. 비공개 멤버인 경우 비공개 속성을 시뮬레이션하는 기술을 사용할 수 있습니다.

<code class="javascript">function Box(col) {
   var color = col;

   this.getColor = function() {
       return color;
   };
}</code>
로그인 후 복사

이 예에서 색상 변수는 생성자 내에서 지역 변수로 선언됩니다. 생성자 외부에서는 직접 접근할 수 없습니다. 그러나 색상 변수의 값을 반환하는 getColor 메소드를 제공합니다.

사용법:

Box 객체의 인스턴스를 생성하려면 new 키워드를 사용합니다. 그 뒤에 생성자 이름이 옵니다.

<code class="javascript">var blueBox = new Box("blue");
alert(blueBox.getColor()); // will alert blue

var greenBox = new Box("green");
alert(greenBox.getColor()); // will alert green</code>
로그인 후 복사

프로토타입을 활용하거나 개인 속성을 시뮬레이션함으로써 JavaScript를 사용하면 객체에 대한 생성자를 정의하고 어느 정도 캡슐화를 시뮬레이션할 수 있습니다.

위 내용은 JavaScript 객체의 생성자를 어떻게 정의합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿