Inhaltsverzeichnis
1 . Erstellen Sie ein Projekt
2 Konfigurieren Sie das Routing
zugreifen. Statische Ressourcen
4. Vorlagen-Engine
5. Fazit
Heim Web-Frontend js-Tutorial Verwenden Sie Koa, um Projekte über Node.js zu erstellen

Verwenden Sie Koa, um Projekte über Node.js zu erstellen

Jun 13, 2018 am 11:38 AM
node.js

Heutzutage widmen viele Front-End-Ingenieure neuen Technologien wie NodeJs und Express Framework oder Koa Framework mehr Aufmerksamkeit. Es kommt selten vor, dass ich in letzter Zeit viel Freizeit habe, also habe ich diese freie Zeit vor dem offiziellen Beginn des Mondneujahrs genutzt, um mich darauf einzulassen und einen Einblick in seine Geheimnisse zu bekommen.

Koa ist ein ultraleichtes serverseitiges Framework, das vom ursprünglichen Express-Team erstellt wurde

Im Vergleich zu Express bietet es zusätzlich einen höheren Freiheitsgrad und die Möglichkeit, Middleware selbst einzuführen Noch wichtiger ist, dass ES6 + Async verwendet wird, um die Callback-Hölle zu vermeiden.

Dies ist jedoch auch auf das Code-Upgrade zurückzuführen, sodass Koa2 eine node.js-Umgebung von v7.60 oder höher erfordert

1 . Erstellen Sie ein Projekt

Erstellen Sie manuell ein Projektverzeichnis und generieren Sie dann schnell eine package.json-Datei

npm init -y
Nach dem Login kopieren

Koa installieren //Die aktuelle Version ist 2.4.1

npm install koa -S
Nach dem Login kopieren

Erstellen Sie dann eine app.js

// app.js

const Koa = require('koa');
const app = new Koa();

app.use(async ctx => {
 ctx.body = 'Wise Wrong';
});

app.listen(3000);
Nach dem Login kopieren

Fügen Sie abschließend den Startbefehl in package.json hinzu

So wird eine einfache Koa-Anwendung fertiggestellt

Sie können npm start ausführen und http://localhost:3000/ im Browser aufrufen, um den Effekt anzuzeigen

Wenn Sie der Meinung sind, dass das manuelle Erstellen des Projekts zu einfach ist umständlich, Sie können das Gerüst koa-generato verwenden, um das Projekt zu generieren

npm install koa-generator -g
Nach dem Login kopieren
koa2 project_name
Nach dem Login kopieren

Dann npm install unter dem Projekt, um die Abhängigkeiten zu installieren, npm start, um das Projekt zu starten

Wenn Sie neu bei Koa sind Es wird empfohlen, zuerst diesen Blog zu lesen und dann das Gerüsttool zu verwenden, damit Sie die Rolle jedes Abhängigkeitspakets besser verstehen können

2 Konfigurieren Sie das Routing

Es gibt einen CTX app.js oben, ein von Koa bereitgestelltes Kontextobjekt, das Anfrage und Antwort kapselt

Jede HTTP-Anfrage wird als Kontextobjekt erstellt

Wir können den vom Benutzer angeforderten Pfad über Kontext abrufen .request.path und senden Sie den Inhalt dann über Context.response.body an den Benutzer

Koas Standardrückgabetyp ist text/plain. Wenn Sie eine HTML-Datei (oder eine Moduldatei) zurückgeben möchten, müssen Sie Kontext.response.type muss geändert werden

Außerdem kann Context.response abgekürzt werden, z. B. wird Context.response.type als Context.type abgekürzt, Context Response.body wird als Context.type abgekürzt

Erstellen Sie eine Verzeichnisansicht unter dem Projekt, um HTML-Dateien zu speichern, und erstellen Sie eine index.html in diesem Verzeichnis. Ändern Sie dann app.js

// app.js// 原生路由

const Koa = require('koa');
const fs = require('fs');
const app = new Koa();

app.use(async (ctx, next) => {
 if (ctx.request.path === '/index') {
 ctx.type = 'text/html';
 ctx.body = fs.createReadStream('./views/index.html');
 } else {
 await next();
 }
});

app.listen(3000);
Nach dem Login kopieren

und besuchen Sie dann http://localhost :3000/index im Browser, Sie können die Seite index.html sehen, aber wenn Sie andere Adressen besuchen, wird sie nicht gefunden

Es scheint sehr umständlich, die URL so zu handhaben, also müssen wir es tun Routing einführen. Middleware koa-router

npm install koa-router -S
Nach dem Login kopieren

Es ist zu beachten, dass beim Importieren von koa-router am Ende eine Klammer hinzugefügt werden muss:

const router = require('koa-router')();
Nach dem Login kopieren

entspricht:

const koaRouter = require('koa-router');
const router = koaRouter();
Nach dem Login kopieren

Erstellen Sie ein Routenverzeichnis zum Speichern von Routingdateien und erstellen Sie index.js

// routes/index.js

const fs = require('fs');
const router = require('koa-router')()

router.get('/index', async (ctx, next) => {
 ctx.type = 'text/html';
 ctx.body = fs.createReadStream('./views/index.html');
});

module.exports = router
Nach dem Login kopieren

Hier können Sie auch die Präfixmethode verwenden, um eine baseUrl für alle Schnittstellen in der hinzuzufügen Datei

// router.prefix('/about')

Ändern Sie die erlaubten Methoden oben app.js

// app.js

const Koa = require('koa');
const app = new Koa();

const index = require('./routes/index')
app.use(index.routes(), index.allowedMethods())

app.listen(3000);
Nach dem Login kopieren

, um die Anforderungsmethode zu überprüfen, wenn Sie Post Request to verwenden Wenn Sie auf die Get-Schnittstelle zugreifen, wird direkt ein Fehler zurückgegeben

Darüber hinaus können Sie auch Variablen in der URL hinzufügen und dann über Context.params.name 3 auf

router.get('/about/:name', async (ctx, next) => {
 ctx.body = `I am ${ctx.params.name}!`;
});
Nach dem Login kopieren

zugreifen. Statische Ressourcen

Wenn Sie in der obigen index.html statische Ressourcen wie CSS einführen müssen, müssen Sie koa-static

npm install koa-static -S
Nach dem Login kopieren

verwenden, um ein öffentliches Verzeichnis zum Speichern statischer Ressourcen zu erstellen

Fügen Sie dann den folgenden Code in app.js hinzu

const static = require('koa-static');
// 将 public 目录设置为静态资源目录
const main = static(__dirname + '/public');
app.use(main);
Nach dem Login kopieren

Tatsächlich können diese drei Codezeilen auch optimiert werden

app.use(require('koa-static')(__dirname + '/public'));
Nach dem Login kopieren

und dann die entsprechenden Dateien kann in index.html eingeführt werden

4. Vorlagen-Engine

Die obige Route verwendet das fs-Modul, um die HTML-Datei direkt zu lesen

Es wird eher empfohlen, bei der Entwicklung von Views-Middleware Koa zu verwenden, um die Seite zu rendern

npm install koa-views -S
Nach dem Login kopieren

Legen Sie das View-Verzeichnis als Vorlagenverzeichnis in app.js fest

const views = require('koa-views')
app.use(views(__dirname + '/views'));
Nach dem Login kopieren

Dann in der Routing-Datei, Sie Sie können die Render-Methode verwenden

// routes/index.js

const router = require('koa-router')()

router.get('/index', async (ctx, next) => {
 await ctx.render('index');
});

module.exports = router
Nach dem Login kopieren

Das Obige ist die Methode zum direkten Rendern von HTML-Dateien. Wenn Sie eine Vorlagen-Engine einführen möchten, können Sie das Erweiterungsfeld hinzufügen, um den Vorlagentyp festzulegen

app.use(views(__dirname + '/views', {
 extension: 'pug' // 以 pug 模版为例
}))
Nach dem Login kopieren

5. Fazit

Wenn Express als Webstorm angesehen wird, dann ist Koa großartig

Als Express populär wurde, wurden seine komplizierten Abhängigkeiten von vielen Entwicklern kritisiert

Also zerlegte das Express-Team Drücken Sie nur das grundlegendste Grundgerüst aus, damit Entwickler es selbst zusammenbauen können, das ist Koa

Wie im Artikel erwähnt, ist es zu umständlich, bei Null anzufangen. Sie können das Gerüst Koa-Generato verwenden, um sich schnell zu entwickeln.

Ich empfehle jedoch, nach dem Kennenlernen von Koa ein für Sie geeignetes Gerüst zu bauen Projekt

Das Obige habe ich für Sie zusammengestellt. Ich hoffe, es wird Ihnen in Zukunft hilfreich sein.

Verwandte Artikel:

Vergleich der Verwendung von Express und Koa (ausführliches Tutorial)

Die erste Verwendung der Stiftinstallationsmethode in vue (ausführliches Tutorial-Tutorial)

Entwicklung von Warenkomponenten im Vue-Framework

Das obige ist der detaillierte Inhalt vonVerwenden Sie Koa, um Projekte über Node.js zu erstellen. 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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

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)

Ein Artikel über Speichersteuerung in Node Ein Artikel über Speichersteuerung in Node Apr 26, 2023 pm 05:37 PM

Der nicht blockierende und ereignisgesteuerte Knotendienst hat den Vorteil eines geringen Speicherverbrauchs und eignet sich sehr gut für die Verarbeitung massiver Netzwerkanforderungen. Unter der Voraussetzung massiver Anfragen müssen Probleme im Zusammenhang mit der „Speicherkontrolle“ berücksichtigt werden. 1. Der Garbage-Collection-Mechanismus und die Speicherbeschränkungen von V8 Js wird von der Garbage-Collection-Maschine gesteuert

Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Detaillierte grafische Erläuterung des Speichers und des GC der Node V8-Engine Mar 29, 2023 pm 06:02 PM

Dieser Artikel vermittelt Ihnen ein detailliertes Verständnis des Speichers und Garbage Collectors (GC) der NodeJS V8-Engine. Ich hoffe, er wird Ihnen hilfreich sein!

Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Lassen Sie uns darüber sprechen, wie Sie das beste Node.js-Docker-Image auswählen. Dec 13, 2022 pm 08:00 PM

Die Auswahl eines Docker-Images für Node mag trivial erscheinen, aber die Größe und potenziellen Schwachstellen des Images können erhebliche Auswirkungen auf Ihren CI/CD-Prozess und Ihre Sicherheit haben. Wie wählen wir also das beste Node.js-Docker-Image aus?

Lassen Sie uns ausführlich über das File-Modul in Node sprechen Lassen Sie uns ausführlich über das File-Modul in Node sprechen Apr 24, 2023 pm 05:49 PM

Das Dateimodul ist eine Kapselung der zugrunde liegenden Dateioperationen, wie z. B. Lesen/Schreiben/Öffnen/Schließen/Löschen von Dateien, Hinzufügen usw. Das größte Merkmal des Dateimoduls besteht darin, dass alle Methoden zwei Versionen von **synchronem** und **bereitstellen. asynchron**, mit Methoden mit dem Suffix sync sind alle Synchronisationsmethoden, und diejenigen ohne sind alle heterogene Methoden.

Node.js 19 ist offiziell veröffentlicht, lassen Sie uns über seine 6 Hauptfunktionen sprechen! Node.js 19 ist offiziell veröffentlicht, lassen Sie uns über seine 6 Hauptfunktionen sprechen! Nov 16, 2022 pm 08:34 PM

Node 19 wurde offiziell veröffentlicht. Dieser Artikel wird Ihnen eine detaillierte Erklärung der 6 Hauptfunktionen von Node.js 19 geben. Ich hoffe, er wird Ihnen hilfreich sein!

Lassen Sie uns über den GC-Mechanismus (Garbage Collection) in Node.js sprechen Lassen Sie uns über den GC-Mechanismus (Garbage Collection) in Node.js sprechen Nov 29, 2022 pm 08:44 PM

Wie führt Node.js GC (Garbage Collection) durch? Der folgende Artikel führt Sie durch.

Lassen Sie uns über die Ereignisschleife in Node sprechen Lassen Sie uns über die Ereignisschleife in Node sprechen Apr 11, 2023 pm 07:08 PM

Die Ereignisschleife ist ein grundlegender Bestandteil von Node.js und ermöglicht die asynchrone Programmierung, indem sie sicherstellt, dass der Hauptthread nicht blockiert wird. Das Verständnis der Ereignisschleife ist für die Erstellung effizienter Anwendungen von entscheidender Bedeutung. Der folgende Artikel wird Ihnen ein detailliertes Verständnis der Ereignisschleife in Node vermitteln. Ich hoffe, er wird Ihnen hilfreich sein!

Was soll ich tun, wenn der Knoten den Befehl npm nicht verwenden kann? Was soll ich tun, wenn der Knoten den Befehl npm nicht verwenden kann? Feb 08, 2023 am 10:09 AM

Der Grund, warum der Knoten den Befehl npm nicht verwenden kann, liegt darin, dass die Umgebungsvariablen nicht richtig konfiguriert sind. Die Lösung ist: 1. Öffnen Sie „Systemeigenschaften“ 2. Suchen Sie nach „Umgebungsvariablen“ -> „Systemvariablen“ und bearbeiten Sie dann die Umgebung Variablen; 3. Suchen Sie den Speicherort des NodeJS-Ordners. 4. Klicken Sie auf „OK“.

See all articles