Inhaltsverzeichnis
Vorwort
举个例子
补充说明
初步模拟
返回值效果
返回值为基本类型
返回值为对象
Zusätzliche Erklärung🎜
🎜Der Rückgabewert ist ein Basistyp🎜
🎜Der Rückgabewert ist ein Objekt🎜
Heim Web-Frontend js-Tutorial JavaScript übernimmt die Kontrolle über Neues

JavaScript übernimmt die Kontrolle über Neues

Apr 08, 2022 pm 07:12 PM
javascript

Dieser Artikel vermittelt Ihnen relevantes Wissen über Javascript, das hauptsächlich verwandte Probleme mit dem neuen Operator einführt, der eine Instanz eines benutzerdefinierten Objekttyps oder eines der integrierten Objekttypen mit einem Konstruktor erstellt .

JavaScript übernimmt die Kontrolle über Neues

【Verwandte Empfehlungen: Javascript-Video-Tutorial

Vorwort

Was ist neu? new呢?

new运算符创建一个用户定义的对象类型的实例或具有构造函数的内置对象类型之一。

光看定义还是有几分晦涩,直接看一个具体的例子,来了解一下JavaScript中的new实现的功能。

举个例子

// 现实中瘦不了,但网络中一定要保持苗条
function Thin_User(name, age) {
    this.name = name;
    this.age = age;
}

Thin_User.prototype.eatToMuch = function () {
    // 白日做梦吧,留下肥胖的泪水
    console.log('i eat so much, but i\'m very thin!!!');
}

Thin_User.prototype.isThin = true;

const xiaobao = new Thin_User('zcxiaobao', 18);
console.log(xiaobao.name);   // zcxiaobao
console.log(xiaobao.age);    // 18
console.log(xiaobao.isThin); // true
// i eat so much, but i'm very thin!!!
xiaobao.eatToMuch();
Nach dem Login kopieren

通过上面这个例子,我们可以发现xiaobao可以:

  • 访问到构造函数Thin_User中属性
  • 访问到Thin_User.prototype中属性

描述得更直白一点,new做了这些事:

  • 创建了一个空对象,对象的__proto__->Thin_User.prototype
  • 执行构造函数,并将this指向新对象
  • 返回新对象

补充说明

由于new是关键字,我们无法像模拟数组高阶方法一样覆盖,因此我们写一个函数createObject,来模拟new的效果。使用具体如下:

function Thin_User(name, age) {}

const u1 = new Thin_user(...)
const u2 = createObject(Thin_User, ...a\)
Nach dem Login kopieren

初步模拟

根据上面分析,createObject编写的大致步骤为:

  • 创建一个新对象obj
  • 设置obj.__proto__->constructor.prototype(但JavaScript不推荐直接修改__proto__属性,提供了setPrototypeOf方法来专门修改原型)
  • 使用constructor.call/apply(obj, ...),将属性添加到obj
  • 返回obj

__proto__和prototype,可以看JavaScript之彻底理解原型与原型链
call/apply,可以看JavaScript之手撕call、apply

学习完这些,我们就可以编写第一版代码:

function createObject(Con) {
    // 创建新对象obj
    // var obj = {};也可以
    var obj = Object.create(null);

    // 将obj.__proto__ -> 构造函数原型
    // (不推荐)obj.__proto__ = Con.prototype
    Object.setPrototypeOf(obj, Con.prototype);

    // 执行构造函数
    Con.apply(obj, [].slice.call(arguments, 1));

    // 返回新对象
    return obj;}
Nach dem Login kopieren

返回值效果

众所周知,函数是有返回值的,那构造函数如果有返回值,最终执行new后返回的结果是怎样的那?

返回值为基本类型

假设构造函数返回值为一个基本类型,我们来看一下最后的返回结果:

function Thin_User(name, age) {
    this.name = name;
    this.age = age;
    return 'i will keep thin forever';
}

Thin_User.prototype.eatToMuch = function () {
    console.log('i eat so much, but i\'m very thin!!!');
}

Thin_User.prototype.isThin = true;

const xiaobao = new Thin_User('zcxiaobao', 18);
console.log(xiaobao.name);   // zcxiaobao
console.log(xiaobao.age);    // 18
console.log(xiaobao.isThin); // true
// i eat so much, but i'm very thin!!!
xiaobao.eatToMuch();
Nach dem Login kopieren

最后的返回结果好像受到任何干扰,难道构造函数不会对返回值进行处理吗?

不急,我们来接着测试一下返回值为对象的情况。

返回值为对象

function Thin_User(name, age) {
    this.name = name;
    this.age = age;
    return {
        name: name,
        age: age * 10,
        fat: true
    }
}

Thin_User.prototype.eatToMuch = function () {
    // 白日做梦吧,留下肥胖的泪水
    console.log('i eat so much, but i\'m very thin!!!');
}

Thin_User.prototype.isThin = true;

const xiaobao = new Thin_User('zcxiaobao', 18);
// Error: xiaobao.eatToMuch is not a function
xiaobao.eatToMuch();
Nach dem Login kopieren

当我执行eatToMuch时,控制台直接报错,没有当前函数,于是我打印了xiaobao对象:
JavaScript übernimmt die Kontrolle über Neues

发现xiaobao对象的age发生了改变,而且增加了fat

Der new-Operator erstellt eine Instanz eines benutzerdefinierten Objekttyps oder eines der integrierten Objekttypen, der über einen Konstruktor verfügt.

Es ist immer noch etwas unklar, wenn man sich nur die Definition ansieht. Schauen wir uns ein konkretes Beispiel an, um die von new in JavaScript implementierten Funktionen zu verstehen.

Zum Beispiel

function createObject(Con) {
    // 创建新对象obj
    // var obj = {};也可以
    var obj = Object.create(null);

    // 将obj.__proto__ -> 构造函数原型
    // (不推荐)obj.__proto__ = Con.prototype
    Object.setPrototypeOf(obj, Con.prototype);

    // 执行构造函数,并接受构造函数返回值
    const ret = Con.apply(obj, [].slice.call(arguments, 1));

    // 若构造函数返回值为对象,直接返回该对象
    // 否则返回obj
    return typeof(ret) === 'object' ? ret: obj;}
Nach dem Login kopieren
Durch das obige Beispiel können wir feststellen, dass xiaobao:

  • Auf die Konstruktor-Thin_User-Attribute zugreifen kann im Code>
  • Zugriff auf die Attribute in Thin_User.prototype
Die Beschreibung ist einfacher, new erledigt diese Dinge :
  • Erstellen Sie ein leeres Objekt. Der __proto__->Thin_User.prototype
  • des Objekts führt den Konstruktor aus und legt diesen fest Auf neues Objekt zeigen
  • Neues Objekt zurückgeben

Zusätzliche Erklärung🎜

🎜Da new ein Schlüsselwort ist, können wir' Um es nicht wie die Methode höherer Ordnung zum Simulieren von Arrays zu überschreiben, schreiben wir eine Funktion createObject, um die Wirkung von new zu simulieren. Die spezifische Verwendung ist wie folgt: 🎜rrreee🎜🎜Vorläufige Simulation🎜🎜🎜Gemäß der obigen Analyse sind die allgemeinen Schritte zum Schreiben von createObject: 🎜
  • Erstellen Sie ein neues Objekt obj
  • Set obj.__proto__->constructor.prototype(🎜JavaScript empfiehlt jedoch nicht, das __proto__-Attribut direkt zu ändern, und stellt die setPrototypeOf-Methode speziell dafür bereit den Prototyp ändern🎜)
  • Verwenden Sie constructor.call/apply(obj, ...), um Eigenschaften zu obj
  • Gib obj
🎜__proto__ und prototyp zurück, du kannst JavaScript sehen, um den Prototyp und die Prototypenkette vollständig zu verstehen
call/apply code>, Sie können den Aufruf und die Anwendung von JavaScript sehen🎜
🎜Nachdem wir diese gelernt haben, können wir die erste Version des Codes schreiben:🎜rrreee🎜🎜Rückgabewerteffekt🎜🎜🎜Wie wir alle Wissen Sie, Funktionen haben Rückgabewerte? Wenn der Konstruktor einen Rückgabewert hat, welches Ergebnis wird nach der Ausführung von new zurückgegeben? 🎜

🎜Der Rückgabewert ist ein Basistyp🎜

🎜Angenommen, der Rückgabewert des Konstruktors ist ein Basistyp, werfen wir einen Blick auf das endgültige Rückgabeergebnis: 🎜rrreee🎜Das endgültige Rückgabeergebnis scheint zu sein Könnte es sein, dass der Konstruktor den Rückgabewert nicht verarbeitet? 🎜🎜Keine Eile, testen wir weiter den Fall, in dem der Rückgabewert ein Objekt ist. 🎜

🎜Der Rückgabewert ist ein Objekt🎜

rrreee🎜Als ich eatToMuch ausführte, meldete die Konsole direkt einen Fehler und es gab keine aktuelle Funktion, also habe ich xiaobao gedruckt Objekt:
Bildbeschreibung hier einfügen🎜🎜 Es wurde festgestellt, dass sich das age des xiaobao-Objekts geändert hat und das Attribut fat hinzugefügt wurde, was genau dasselbe ist als Rückgabewert des Konstruktors. 🎜🎜Nachdem wir diese beiden Beispiele gelesen haben, können wir grundsätzlich die Situation klären, in der der Konstruktor einen Wert zurückgibt: 🎜Wenn der Konstruktor ein Objekt zurückgibt, wird das Objekt direkt zurückgegeben. 🎜🎜🎜Simulation der endgültigen Version🎜rrreee🎜[Verwandte Empfehlungen: 🎜Javascript-Video-Tutorial🎜]🎜

Das obige ist der detaillierte Inhalt vonJavaScript übernimmt die Kontrolle über Neues. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So implementieren Sie ein Online-Spracherkennungssystem mit WebSocket und JavaScript So implementieren Sie ein Online-Spracherkennungssystem mit WebSocket und JavaScript Dec 17, 2023 pm 02:54 PM

So implementieren Sie mit WebSocket und JavaScript ein Online-Spracherkennungssystem. Einführung: Mit der kontinuierlichen Weiterentwicklung der Technologie ist die Spracherkennungstechnologie zu einem wichtigen Bestandteil des Bereichs der künstlichen Intelligenz geworden. Das auf WebSocket und JavaScript basierende Online-Spracherkennungssystem zeichnet sich durch geringe Latenz, Echtzeit und plattformübergreifende Eigenschaften aus und hat sich zu einer weit verbreiteten Lösung entwickelt. In diesem Artikel wird erläutert, wie Sie mit WebSocket und JavaScript ein Online-Spracherkennungssystem implementieren.

WebSocket und JavaScript: Schlüsseltechnologien zur Implementierung von Echtzeitüberwachungssystemen WebSocket und JavaScript: Schlüsseltechnologien zur Implementierung von Echtzeitüberwachungssystemen Dec 17, 2023 pm 05:30 PM

WebSocket und JavaScript: Schlüsseltechnologien zur Realisierung von Echtzeit-Überwachungssystemen Einführung: Mit der rasanten Entwicklung der Internet-Technologie wurden Echtzeit-Überwachungssysteme in verschiedenen Bereichen weit verbreitet eingesetzt. Eine der Schlüsseltechnologien zur Erzielung einer Echtzeitüberwachung ist die Kombination von WebSocket und JavaScript. In diesem Artikel wird die Anwendung von WebSocket und JavaScript in Echtzeitüberwachungssystemen vorgestellt, Codebeispiele gegeben und deren Implementierungsprinzipien ausführlich erläutert. 1. WebSocket-Technologie

Verwendung von JavaScript und WebSocket zur Implementierung eines Echtzeit-Online-Bestellsystems Verwendung von JavaScript und WebSocket zur Implementierung eines Echtzeit-Online-Bestellsystems Dec 17, 2023 pm 12:09 PM

Einführung in die Verwendung von JavaScript und WebSocket zur Implementierung eines Online-Bestellsystems in Echtzeit: Mit der Popularität des Internets und dem Fortschritt der Technologie haben immer mehr Restaurants damit begonnen, Online-Bestelldienste anzubieten. Um ein Echtzeit-Online-Bestellsystem zu implementieren, können wir JavaScript und WebSocket-Technologie verwenden. WebSocket ist ein Vollduplex-Kommunikationsprotokoll, das auf dem TCP-Protokoll basiert und eine bidirektionale Kommunikation zwischen Client und Server in Echtzeit realisieren kann. Im Echtzeit-Online-Bestellsystem, wenn der Benutzer Gerichte auswählt und eine Bestellung aufgibt

So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript Dec 17, 2023 am 09:39 AM

So implementieren Sie ein Online-Reservierungssystem mit WebSocket und JavaScript. Im heutigen digitalen Zeitalter müssen immer mehr Unternehmen und Dienste Online-Reservierungsfunktionen bereitstellen. Es ist von entscheidender Bedeutung, ein effizientes Online-Reservierungssystem in Echtzeit zu implementieren. In diesem Artikel wird erläutert, wie Sie mit WebSocket und JavaScript ein Online-Reservierungssystem implementieren, und es werden spezifische Codebeispiele bereitgestellt. 1. Was ist WebSocket? WebSocket ist eine Vollduplex-Methode für eine einzelne TCP-Verbindung.

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems Dec 17, 2023 pm 05:13 PM

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Wettervorhersagesystems Einführung: Heutzutage ist die Genauigkeit von Wettervorhersagen für das tägliche Leben und die Entscheidungsfindung von großer Bedeutung. Mit der Weiterentwicklung der Technologie können wir genauere und zuverlässigere Wettervorhersagen liefern, indem wir Wetterdaten in Echtzeit erhalten. In diesem Artikel erfahren Sie, wie Sie mit JavaScript und WebSocket-Technologie ein effizientes Echtzeit-Wettervorhersagesystem aufbauen. In diesem Artikel wird der Implementierungsprozess anhand spezifischer Codebeispiele demonstriert. Wir

Einfaches JavaScript-Tutorial: So erhalten Sie den HTTP-Statuscode Einfaches JavaScript-Tutorial: So erhalten Sie den HTTP-Statuscode Jan 05, 2024 pm 06:08 PM

JavaScript-Tutorial: So erhalten Sie HTTP-Statuscode. Es sind spezifische Codebeispiele erforderlich. Vorwort: Bei der Webentwicklung ist häufig die Dateninteraktion mit dem Server erforderlich. Bei der Kommunikation mit dem Server müssen wir häufig den zurückgegebenen HTTP-Statuscode abrufen, um festzustellen, ob der Vorgang erfolgreich ist, und die entsprechende Verarbeitung basierend auf verschiedenen Statuscodes durchführen. In diesem Artikel erfahren Sie, wie Sie mit JavaScript HTTP-Statuscodes abrufen und einige praktische Codebeispiele bereitstellen. Verwenden von XMLHttpRequest

So verwenden Sie insertBefore in Javascript So verwenden Sie insertBefore in Javascript Nov 24, 2023 am 11:56 AM

Verwendung: In JavaScript wird die Methode insertBefore() verwendet, um einen neuen Knoten in den DOM-Baum einzufügen. Diese Methode erfordert zwei Parameter: den neuen Knoten, der eingefügt werden soll, und den Referenzknoten (d. h. den Knoten, an dem der neue Knoten eingefügt wird).

JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Bildverarbeitungssystems JavaScript und WebSocket: Aufbau eines effizienten Echtzeit-Bildverarbeitungssystems Dec 17, 2023 am 08:41 AM

JavaScript ist eine in der Webentwicklung weit verbreitete Programmiersprache, während WebSocket ein Netzwerkprotokoll für die Echtzeitkommunikation ist. Durch die Kombination der leistungsstarken Funktionen beider können wir ein effizientes Echtzeit-Bildverarbeitungssystem erstellen. In diesem Artikel wird erläutert, wie dieses System mithilfe von JavaScript und WebSocket implementiert wird, und es werden spezifische Codebeispiele bereitgestellt. Zunächst müssen wir die Anforderungen und Ziele des Echtzeit-Bildverarbeitungssystems klären. Angenommen, wir haben ein Kameragerät, das Bilddaten in Echtzeit sammeln kann

See all articles