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 중국어 웹사이트의 기타 관련 기사를 참조하세요!