>웹 프론트엔드 >JS 튜토리얼 >JavaScript에서 `.apply()`와 함께 `new` 연산자를 사용하여 가변 인수가 있는 객체를 생성할 수 있나요?

JavaScript에서 `.apply()`와 함께 `new` 연산자를 사용하여 가변 인수가 있는 객체를 생성할 수 있나요?

Patricia Arquette
Patricia Arquette원래의
2024-12-06 21:43:15651검색

Can You Use the `new` Operator with `.apply()` in JavaScript to Create Objects with Variable Arguments?

new 연산자로 .apply() 메서드 호출: 실현 가능합니까?

JavaScript에서는 new 연산자를 사용하여 객체 인스턴스를 생성하는 것이 바람직할 수 있습니다. 가변 개수의 인수를 생성자에 전달하는 동안. 하지만 제공하신 코드 조각으로는 이 작업을 수행할 수 없습니다.

대체 솔루션

1. Matthew Crumley의 접근 방식:

이 솔루션에는 Something 프로토타입을 확장하고 apply() 메서드에 대한 래퍼를 제공하는 새로운 함수 F를 만드는 작업이 포함됩니다. 다음과 같이 구현할 수 있습니다.

var createSomething = (function() {
    function F(args) {
        return Something.apply(this, args);
    }
    F.prototype = Something.prototype;

    return function() {
        return new F(arguments);
    }
})();

2. ECMAScript 5 솔루션:

ECMAScript 5에서는 더욱 간결한 솔루션을 위해 Function.prototype.bind 메서드를 사용할 수 있습니다.

function newCall(Cls) {
    return new (Function.prototype.bind.apply(Cls, arguments));
}

이 함수는 다음과 같이 활용할 수 있습니다.

var s = newCall(Something, a, b, c);

또는 심지어 직접:

var s = new (Function.prototype.bind.call(Something, null, a, b, c));

설명:

바인드 메소드를 사용하면 원래 함수와 동일한 컨텍스트(이 값)를 갖지만 다음을 사용하는 새 함수를 생성할 수 있습니다. 제한된 수의 인수. apply() 메소드를 사용하면 바인딩된 함수에 가변 개수의 인수를 전달할 수 있습니다. 마지막으로 new 연산자를 바인딩된 함수에 적용하여 새 객체 인스턴스를 생성할 수 있습니다.

위 내용은 JavaScript에서 `.apply()`와 함께 `new` 연산자를 사용하여 가변 인수가 있는 객체를 생성할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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