Als ich anfing, Node zu lernen, entdeckte ich eine Situation, die völlig anders war als meine vorherigen Ansichten – wofür wird JavaScript in Ihren Augen verwendet? Spezialeffekte? oder nur Interaktion mit dem Kunden? Man kann sagen, dass JavaScript zuerst im Browser ausgeführt wurde. Wenn Sie es jedoch so betrachten, stellt Ihnen der Browser lediglich einen Kontext (Kontext) zur Verfügung, der definiert, was mit JavaScript getan werden kann Ähnliches Unternehmen. Es definiert, was Sie hier tun können, sagt aber nicht viel darüber aus, was die JavaScript-Sprache selbst tun kann. Tatsächlich kann JavaScript als vollständige Sprache in verschiedenen Kontexten verwendet werden und unterschiedliche Fähigkeiten widerspiegeln. Die hier erwähnten Nodejs stellen tatsächlich einen Kontext bereit, eine laufende Umgebung, die die Ausführung von JavaScript-Code im Backend (aus der Browserumgebung heraus) ermöglicht.
Der Kern der Routing-Auswahl ist das Routing. Wie der Name schon sagt, bedeutet Routing, dass wir unterschiedliche Verarbeitungsmethoden für unterschiedliche URLs haben, z. B. die Verarbeitung der Geschäftslogik von /start und die Verarbeitung der Geschäftslogik von /upload . In einer realistischen Implementierung „endet“ der Routing-Prozess im Routing-Modul, und das Routing-Modul ist nicht das Modul, das tatsächlich „Maßnahmen“ für die Anfrage ergreift, da es sonst nicht verfügbar ist, wenn unsere Anwendung komplexer wird .
Hier erstellen wir zunächst ein Modul namens requestHandlers und fügen jedem Request-Handler eine Platzhalterfunktion hinzu:
Funktion start(){
console.log("Anforderungshandler 'start' wurde aufgerufen.");
Funktion sleep(milliSeconds){
var startTime=new Date().getTime();
while(new Date().getTime()
Schlaf(10000);
Geben Sie „Hallo Start“ zurück;
}
Funktion upload(){
console.log("Anforderungshandler 'upload' wurde aufgerufen.");
Geben Sie „Hallo Upload“ zurück;
}
exports.start=start;
exports.upload=upload;
Auf diese Weise können wir den Request-Handler und das Routing-Modul verbinden, sodass das Routing „einen Pfad hat, dem es folgen muss“. Danach haben wir festgestellt, dass eine Reihe von Anforderungshandlern über ein Objekt geleitet werden und dieses Objekt mithilfe einer losen Kopplungsmethode in die Funktion router() eingefügt werden muss. Die Hauptdatei index.js:
var server=require("./server"
var router=require("./router"
var requestHandlers=require("./requestHandlers");
var handle={};
handle["/"]=requestHandlers.start;
handle["/start"]=requestHandlers.start;
handle["/upload"]=requestHandlers.upload;
server.start(router.route,handle);
Wie oben gezeigt, ist die Zuordnung verschiedener URLs zu demselben Anforderungshandler einfach: Fügen Sie einfach eine Eigenschaft mit dem Schlüssel „/“ zum Objekt hinzu, das requestHandlers.start entspricht. Auf diese Weise können wir einfach konfigurieren, dass Anfragen für /start und / vom Starthandler verarbeitet werden. Nachdem wir die Definition des Objekts abgeschlossen haben, übergeben wir es als zusätzlichen Parameter an den Server, siehe server.js:
Code kopieren
Der Code lautet wie folgt:
var http=require("http");
var url=require("url");
Funktion start(route,handle){
Funktion onRequest(request,response){
var pathname=url.parse(request.url).pathname;
console.log("Anfrage für "Pfadname" erhalten.");
Route(Handle,Pfadname);
Response.writeHead(200,{"Content-Type":"text/plain"});
var content=route(handle,pathname);
Response.write(content);
response.end();
}
http.createServer(onRequest).listen(8888);
Console.log("Server wurde gestartet.");
}
exports.start=start;
Auf diese Weise wird der Handle-Parameter zur Funktion start() hinzugefügt und das Handle-Objekt als erster Parameter an die Rückruffunktion route() übergeben. Route.js ist unten definiert:
Code kopieren
Der Code lautet wie folgt:
Mit dem obigen Code prüfen wir zunächst, ob der dem angegebenen Pfad entsprechende Anforderungshandler existiert, und rufen, falls vorhanden, die entsprechende Funktion direkt auf. Wir können die Anforderungsverarbeitungsfunktion vom übergebenen Objekt auf die gleiche Weise abrufen wie das Abrufen von Elementen aus dem assoziativen Array, d Behandeln Sie diesen Pfad.“ Der laufende Effekt des Programms ist wie folgt: