> 웹 프론트엔드 > JS 튜토리얼 > 객체를 생성하고 관리하기 위해 JavaScript에서 `new` 키워드는 어떻게 작동합니까?

객체를 생성하고 관리하기 위해 JavaScript에서 `new` 키워드는 어떻게 작동합니까?

Patricia Arquette
풀어 주다: 2024-12-26 15:26:11
원래의
402명이 탐색했습니다.

How Does the `new` Keyword Work in JavaScript to Create and Manage Objects?

JavaScript의 'new' 키워드 해석: 기능 및 사용 사례 공개

JavaScript는 일반적으로 비객체 지향으로 인식됩니다. 에서 'new' 키워드는 객체를 생성하고 조작하는 데 중요한 역할을 합니다. 그 의미를 파헤치고 그 사용법을 둘러싼 근본적인 질문에 답해 보겠습니다.

'new' 키워드란 무엇입니까?

'new' 키워드는 다양한 용도로 사용됩니다. JavaScript:

  1. 새 객체를 인스턴스화합니다.
  2. 생성자 함수의 'prototype' 객체를 새로 생성된 객체의 내부적이고 접근할 수 없는 [[prototype]] 속성으로 사용합니다.
  3. 새로 생성된 객체를 'this' 변수에 할당합니다.
  4. 호출합니다. 생성자 함수는 'this'가 사용될 때마다 새로 생성된 객체를 활용합니다.
  5. 생성자 함수가 null이 아닌 객체 참조를 반환하지 않는 한, 새로 생성된 객체 참조를 반환합니다.

'new'로 문제 해결

'new' 키워드는 JavaScript의 클래스 기반 상속 시스템의 한계를 해결합니다. 동적 속성과 상속을 통해 프로그래머는 전통적인 OOP 메커니즘을 에뮬레이트할 수 있습니다.

'new'를 사용해야 하는 경우와 사용하지 않는 경우

언제든지 'new' 키워드를 사용하세요. 다음을 수행해야 합니다.

  • 클래스와 유사한 인스턴스를 생성하세요. 생성합니다.
  • 특정 속성과 메서드를 사용하여 새 객체를 초기화합니다.
  • 내부 [[prototype]] 속성을 통해 생성자 함수의 'prototype' 객체에 액세스합니다.

다음과 같은 경우 'new'를 사용하지 마세요.

  • 함수를 일반 함수로 호출하려는 경우 function.
  • 생성자 함수에서 대체 객체를 반환하려고 합니다.
  • 내부 [[prototype]] 속성 설정과 상속된 속성 수정이 미치는 영향을 인식하지 못하고 있습니다.

프로토타입과 [[프로토타입]]의 이해 속성

프로토타입 체인은 JavaScript 상속의 기본입니다. 함수의 '프로토타입' 속성은 상속된 속성과 메서드를 설정하기 위해 조작할 수 있는 액세스 가능한 개체를 나타냅니다. 반대로, [[prototype]] 속성은 생성자 함수의 프로토타입을 보유하는 불변 내부 객체입니다.

예:

function ObjMaker() {
  this.a = 'first';
}

ObjMaker.prototype.b = 'second';

const obj1 = new ObjMaker();

console.log(obj1.a); // "first"
console.log(obj1.b); // "second"
로그인 후 복사

이 예에서는 , 'new'는 새로운 'obj1' 객체를 생성하고 해당 [[prototype]] 속성을 'ObjMaker.prototype'으로 설정합니다. 'ObjMaker' 함수를 실행하여 'obj1.a'를 'first'로 초기화합니다. 'prototype' 체인을 사용하면 'obj1'이 [[prototype]] 객체에서 'b' 속성을 상속받을 수 있습니다.

하위 클래스 및 프로토타입 체이닝

서브클래스와 유사한 구조를 설정하려면 서브클래스 생성자의 'prototype' 속성을 슈퍼클래스의 'prototype' 객체로 설정할 수 있습니다. 이렇게 하면 프로토타입 체인이 생성되어 서브클래스가 슈퍼클래스의 속성을 상속하고 재정의할 수 있습니다.

위 내용은 객체를 생성하고 관리하기 위해 JavaScript에서 `new` 키워드는 어떻게 작동합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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