>웹 프론트엔드 >JS 튜토리얼 >JavaScript에서 'new' 키워드는 어떻게 작동하나요?

JavaScript에서 'new' 키워드는 어떻게 작동하나요?

DDD
DDD원래의
2024-12-30 10:10:10525검색

How Does the `new` Keyword Work in JavaScript?

JavaScript의 'new' 키워드 이해

JavaScript에서 'new'를 사용하는 개념은 당황스러울 수 있습니다. 특히 JavaScript의 비 키워드를 고려할 때 더욱 그렇습니다. -객체지향적인 성격. 명확히 말하면 'new'는 다음과 같은 방식으로 작동합니다.

1. 새 개체 만들기:

  • 기본적으로 "객체" 유형의 개체인 새 개체를 설정합니다.

2. 프로토타입 설정:

  • 새로 생성된 객체의 액세스할 수 없는 [[prototype]] 속성을 생성자 함수의 외부 프로토타입 속성과 연결합니다. 이 상속 관계를 통해 생성자의 프로토타입에 정의된 속성에 액세스할 수 있습니다.

3. 'this' 변수 바인딩:

  • 'this' 변수가 새로 생성된 개체를 가리키도록 지정하여 생성자 함수 내에서 개체의 속성과 메서드에 대한 명시적인 액세스를 허용합니다.

4. 생성자 실행:

  • 새로 생성된 객체를 'this'에 대한 컨텍스트로 사용하여 생성자 함수를 실행합니다.

5. 객체 반환:

  • 실행 후 생성자가 명시적으로 다른 객체를 반환하지 않는 한 새로 생성된 객체를 반환합니다.

'new ' 키워드:

  • 'new'를 사용하는 적절한 시나리오는 인스턴스화할 때입니다. 일반적으로 클래스를 생성하거나 객체 지향 동작을 시뮬레이션할 때.
  • 객체 리터럴이나 가상 구문을 사용하여 수동으로 객체를 생성하는 경우에는 적용할 수 없습니다.

예:

function Constructor() {
  this.property = "value";
}

const object = new Constructor();

console.log(object.property); // "value"

프로토타입 체인:

  • 'new'로 생성된 객체에는 프로토타입 체인이 있습니다.
  • 하위 객체 프로토타입의 [[prototype]] 속성은 기본 생성자 함수.
  • 이 체인을 사용하면 기본 생성자의 속성에 정의된 상속 속성에 액세스할 수 있습니다. 프로토타입.

위 내용은 JavaScript에서 'new' 키워드는 어떻게 작동하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.