In den Tiefen der Komplexität von JavaScript verbirgt sich ein mysteriöses Konstrukt, das vor allem für sein verblüffendes Potenzial bekannt ist: der „neue“ Operator. Seine unklaren Funktionsweisen stehen neben der Prototypenkette und lassen viele im Labyrinth des Codes verloren.
Eintauchen in den Mechanismus des neuen Operators
Um die Geheimnisse des „Neuen“ zu enthüllen "-Operator, lassen Sie uns seine komplizierten Vorgänge analysieren:
Eine alternative Linse
Um weiteres Licht auf das rätselhafte „Neue“ zu werfen Lassen Sie uns eine alternative Implementierung untersuchen, die seine Aktionen widerspiegelt:
<code class="javascript">function NEW(f) { var obj, ret, proto; // Prototype verification proto = Object(f.prototype) === f.prototype ? f.prototype : Object.prototype; // Object inheritance from `proto` obj = Object.create(proto); // Function invocation with object as "this" ret = f.apply(obj, Array.prototype.slice.call(arguments, 1)); // Object return if (Object(ret) === ret) { return ret; } return obj; } // Demonstration: function Foo(arg) { this.prop = arg; } Foo.prototype.inherited = 'baz'; var obj = NEW(Foo, 'bar'); console.log(obj.prop); // 'bar' console.log(obj.inherited); // 'baz' console.log(obj instanceof Foo); // true</code>
Dieser Code dient als Leuchtfeuer und beleuchtet, wie der „neue“ Operator seine Aufgaben hinter den Kulissen gewissenhaft erfüllt.
Das obige ist der detaillierte Inhalt vonWie funktioniert der JavaScript-Operator „new'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!