Heim > Web-Frontend > js-Tutorial > Hauptteil

Wie erstelle ich Objekte aus Klassennamen in JavaScript ES6?

Susan Sarandon
Freigeben: 2024-11-11 18:17:03
Original
779 Leute haben es durchsucht

How to Create Objects from Class Names in JavaScript ES6?

Erstellen von Objekten aus Klassennamen in JavaScript ES6

Beim Versuch, Objekte aus Klassennamen mit der Standard-ES6-Syntax zu erstellen, können Fehler auftreten. Der folgende Code veranschaulicht dies:

import "./myModule.js";

class Column {}
class Sequence {}
class Checkbox {}

class ColumnFactory {
    constructor() {
        this.specColumn = {
            __default: 'Column',
            __sequence: 'Sequence',
            __checkbox: 'Checkbox'
        };
    }

    create(name) {
        let className = this.specColumn[name] ? this.specColumn[name] : this.specColumn['__default'];
        return new window[className](name); // this line throws an error
    }
}

let factory = new ColumnFactory();
let column = factory.create('userName');
Nach dem Login kopieren

Der Fehler tritt auf, weil die Klassennamen nicht global zugänglich oder über das Fensterobjekt verfügbar sind.

Lösung:

Um dieses Problem zu beheben, sollten die Klassen selbst anstelle ihrer Namen im Factory-Objekt gespeichert werden. Dieser Ansatz macht die Notwendigkeit, sich auf globale Zugänglichkeit zu verlassen, überflüssig und vereinfacht die Fabrikimplementierung.

import "./myModule.js";

class Column {}
class Sequence {}
class Checkbox {}

const columnFactory = {
    specColumn: {
        __default: Column,    // <--
        __sequence: Sequence, // <--
        __checkbox: Checkbox  // <--
    },
    create(name, ...args) {
        let cls = this.specColumn[name] || this.specColumn.__default;
        return new cls(...args);
    }
};
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie erstelle ich Objekte aus Klassennamen in JavaScript ES6?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage