Heim > Artikel > Web-Frontend > Lernen Sie Nodejs von mir (3) --- Node.js module_javascript-Kenntnisse
Einführung und Informationen
Über die offizielle API von Node.js können Sie sehen, dass Node.js selbst viele Kernmodule bereitstellt http://nodejs.org/api/ Diese Kernmodule werden in Binärdateien kompiliert und können erfordern('Modulname ') Holen Sie es sich; das Kernmodul hat die höchste Ladepriorität (dies wird angezeigt, wenn es ein Modul mit demselben Namen wie das Kernmodul gibt)
(Dieses Mal spreche ich hauptsächlich über benutzerdefinierte Module)
Node.js verfügt auch über einen Modultyp namens Dateimodul, bei dem es sich um eine JavaScript-Codedatei (.js als Dateisuffix), eine Textdatei im JSON-Format (.json als Dateisuffix) oder eine bearbeitete Datei handeln kann C/C-Datei (.node als Dateisuffix);
Die Zugriffsmethode für Dateimodule erfolgt über require('/filename.suffix') require('./filename.suffix') requrie('../filename.suffix') für den Zugriff. Das Dateisuffix kann weggelassen werden. mit Beginnend mit „/“ bedeutet das Laden mit einem absoluten Pfad, beginnend mit „./“ und beginnend mit „../“ bedeutet das Laden mit einem relativen Pfad, und beginnend mit „./“ bedeutet das Laden von Dateien im selben Verzeichnis,Wie bereits erwähnt, kann das Dateisuffix „Nodejs“ weggelassen werden Erstellen Sie ein benutzerdefiniertes Modul
Nehmen Sie als Beispiel eine Theke
Beim Ausführen können Sie feststellen, dass auf alle über exports und module.exports verfügbar gemachten Methoden zugegriffen werden kann!
Wie Sie im Beispiel sehen können, habe ich das Modul zweimal über require('./1_modules_custom_counter') erhalten, aber die Methode printNextCount() startete nach der zweiten Referenz bei 60~~~
Der Grund dafür ist, dass, wenn node.js dasselbe Modul mehrmals über requirerequire aufruft, es nicht wiederholt geladen wird. Node.js speichert alle geladenen Dateimodule basierend auf dem Dateinamen zwischen, sodass es nicht neu geladen wird
Hinweis: Das Caching nach Dateinamen bezieht sich auf den tatsächlichen Dateinamen und es wird nicht als eine andere Datei betrachtet, nur weil die eingehende Pfadform anders ist
In der von mir erstellten Datei 1_modules_custom_counter gibt es eine printOutputVal()-Methode, die keine externen öffentlichen Zugriffsmethoden über Exporte oder module.exports bereitstellt,
Was passiert, wenn direkt auf die Datei 1_modules_load zugegriffen und diese ausgeführt wird?
Die Antwort lautet: TypeError: Object #
Der Unterschied zwischen Exports und module.exports
Nach dem obigen Beispiel kann über die öffentlichen Methoden exports und module.exports darauf zugegriffen werden! Da also beide den Effekt erzielen können, muss es einige Unterschiede geben ~~~ Nehmen wir ein Beispiel!
Lassen Sie uns eine neue 2_modules_diff_exports_load.js-Datei erstellen und sie nennen
Nach dem Aufruf ist das Ausführungsergebnis wie oben gezeigt
Ich gebe den Wert von isEq in der Datei 2_modules_diff_exports_load.js aus ( var isEq = (exports === module.exports); ) und das zurückgegebene true
PS: Beachten Sie, dass es drei Gleichheitszeichen gibt. Wenn Sie sich nicht sicher sind, überprüfen Sie die Informationen bitte selbst!
Ziehen Sie keine voreiligen Schlüsse, sondern ändern Sie diese beiden JS-Dateien in die entsprechenden Codes von module.exports
Nach dem Aufruf ist das Ausführungsergebnis wie oben gezeigt
Ich habe den Wert von isEq in der Datei 2_modules_diff_exports_load.js ausgegeben ( var isEq = (exports === module.exports); ) und false zurückgegeben, was mit den zuvor erhaltenen Ergebnissen nicht übereinstimmt!
PS: Verwenden Sie für den Zugriff nicht Counter.printNextCount(); Sie erhalten nur eine Fehlermeldung
API bietet Erklärung
http://nodejs.org/api/modules.html
Beachten Sie, dass es sich bei exports um einen Verweis auf module.exports handelt, sodass es nur für die Erweiterung geeignet ist. Wenn Sie ein einzelnes Element, z. B. einen Konstruktor, exportieren, sollten Sie stattdessen module.exports direkt verwenden.
exports ist nur module.exports eine Adressreferenz. Nodejs exportiert nur den Punkt von module.exports. Wenn sich der Exportzeiger ändert, bedeutet dies, dass exports nicht mehr auf module.exports zeigt und daher nicht mehr exportiert wird
Beziehen Sie sich auf andere Vereinbarungen:
http://www.hacksparrow.com/node-js-exports-vs-module-exports.html
http://zihua.li/2012/03/use-module-exports-or-exports-in-node/
module.exports ist die eigentliche Schnittstelle und exports ist nur ein Hilfstool dafür. Was letztendlich an den Aufruf zurückgegeben wird, ist module.exports anstelle von exports.
Alle durch Exporte gesammelten Attribute und Methoden werden Module.exports zugewiesen. Dafür gibt es natürlich eine Voraussetzung, dass module.exports selbst keine Eigenschaften und Methoden hat.
Wenn module.exports bereits über einige Eigenschaften und Methoden verfügt, werden die von exports gesammelten Informationen ignoriert.
Exporte und module.exports decken ab
Das Obige versteht im Grunde auch die Beziehung und den Unterschied zwischen Exports und module.exports, aber was ist das Ergebnis, wenn Exports und module.exports gleichzeitig für die printNextCount()-Methode vorhanden sind?
Anrufergebnis
Aus den Ergebnissen geht hervor, dass kein Fehler gemeldet wird, was darauf hinweist, dass er auf diese Weise definiert werden kann, aber am Ende überschreibt module.exports exports
Obwohl das Ergebnis keinen Fehler meldet, kommt es bei dieser Verwendung zwangsläufig zu Problemen während der Entwicklung, also
1. Es ist am besten, module.exports und exports nicht separat zu definieren
2. NodeJs-Entwickler empfehlen die Verwendung von module.exports zum Exportieren von Objekten und exports
zum Exportieren mehrerer Methoden und Variablen.Andere...
Da die API noch andere Methoden bereitstellt, werde ich nicht näher darauf eingehen. Basierend auf dem obigen Beispiel werden Sie es selbst erkennen, sobald Sie es ausgeben
modul.id
Gibt die Modulkennung vom Typ String zurück, normalerweise den vollständig analysierten Dateinamen
module.filename
Gibt einen vollständig analysierten Dateinamen vom Zeichenfolgentyp
zurückModul.geladen
Gibt einen Bool-Typ zurück, der angibt, ob der Ladevorgang abgeschlossen ist
module.parent
Gibt das Modul zurück, das auf dieses Modul verweist
module.children
Gibt ein Array aller Modulobjekte zurück, auf die dieses Modul verweist