JavaScript 상속: Object.create와 new
JavaScript의 상속 개념은 혼란스러울 수 있습니다. 그것. 이 문서의 목적은 가장 널리 사용되는 방법을 명확히 하고 특정 시나리오에 대한 솔루션을 제공하는 것입니다.
Object.create 및 new 이해
Object.create는 기존 개체를 상속하여 새 개체를 만듭니다. 이는 기본 개체를 만든 다음 추가 속성 및 메서드를 사용하여 확장하려는 경우에 유용합니다. Object.create의 구문은 다음과 같습니다.
Object.create(prototype[, propertiesObject])
반면에 new 키워드는 객체의 새 인스턴스를 생성하고 해당 생성자 함수를 호출하는 데 사용됩니다. new의 구문은 다음과 같습니다.
new ConstructorFunction([arguments])
상속을 위한 올바른 방법 선택
Object.create와 new 중 선택은 특정 요구 사항에 따라 다릅니다. Object.create는 생성자를 호출하지 않고 상속하려는 기본 개체를 만드는 데 이상적입니다. 예:
const Model = { // Base object properties and methods... }; const RestModel = Object.create(Model);
그러나 상속 객체에서 기본 객체의 생성자 함수를 호출하려면 new를 사용해야 합니다. 예:
function Model() { // Base object constructor... } function RestModel() { Model.call(this); // Additional properties and methods... }
시나리오에 대한 솔루션
귀하의 경우에는 Model 기본 개체에서 RestModel을 상속하려고 합니다. Object.create를 사용하여 이를 달성하려면 다음을 수행합니다.
RestModel.prototype = Object.create(Model.prototype);
이렇게 하면 Model 프로토타입에서 상속되는 새로운 RestModel 프로토타입이 생성됩니다.
위 내용은 JavaScript 상속을 위해 new 대신 Object.create를 선택해야 하는 경우는 언제입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!