„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Wie instanziiere ich JavaScript-Objekte dynamisch mithilfe von in Variablen gespeicherten Klassennamen?

Wie instanziiere ich JavaScript-Objekte dynamisch mithilfe von in Variablen gespeicherten Klassennamen?

Veröffentlicht am 03.11.2024
Durchsuche:858

How to Dynamically Instantiate JavaScript Objects Using Class Names Stored in Variables?

Instanziieren von JavaScript-Objekten mithilfe dynamischer Klassennamen

Angenommen, Sie befinden sich in einer Situation, in der Sie JavaScript-Objekte mithilfe von in Variablen gespeicherten Klassennamen instanziieren müssen. Hier ist ein anschauliches Beispiel:

// Define the class
MyClass = Class.extend({});

// Store the class name in a string
var classNameString = 'MyClass';

// Instantiate the object using the class name string
var myObject = new classNameString();

Dieser Ansatz funktioniert jedoch nicht. Um das gewünschte Verhalten zu erreichen, können Sie die folgende Alternative verwenden:

var myObject = window[classNameString];

Dieser Ansatz funktioniert, weil das Fensterobjekt einen Verweis auf den globalen Bereich enthält, der Folgendes enthält: die definierten Klassen. Durch Zugriff auf den in classNameString als Eigenschaft von window gespeicherten Klassennamen können Sie die Klasse dynamisch abrufen und instanziieren.

Freigabeerklärung Dieser Artikel wird unter folgender Adresse abgedruckt: 1729576035 Bei Verstößen wenden Sie sich bitte an [email protected], um ihn zu löschen
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3