この記事では、Node.js と Express.js を使用した Web サイトの構築について詳しく説明します。 Express.js は、Node.js 上に堅牢でスケーラブルな Web アプリケーションを作成するための重要なフレームワークです。今日は、ルーティング、ミドルウェア、テンプレート エンジン、およびCookieセッション。
コンセプトのハイライト:
例) この例では、ミドルウェアは受信リクエストごとに実行され、メッセージをコンソールに記録します。
const express = require('express'); const app = express(); app.use((req, res, next) => { console.log('Middleware running for every request.'); next(); });
例) この例では、ミドルウェアは /users で始まるルートに対してのみトリガーされます。
app.use('/users', (req, res, next) => { console.log('Middleware only for /users route.'); next(); });
例) 各メソッドは、ユーザー管理のための CRUD 操作 (作成、読み取り、更新、削除) の異なる部分を処理します。
app.get('/users', (req, ress) => { res.send('Fetching all users'); }); app.post('/users', (req, res) => { res.send('Creating a new user'); }); app.put('/users/:id', (req, res) => { res.send(`Updating user with ID: ${req.params.id}`); }); app.delete('/users/:id', (req, res) => { res.send('Deleting user with ID: ${req.params.id}`); });
主な特徴:
例) この例では、ミドルウェアがカスタム データをリクエスト オブジェクトに追加し、ルート ハンドラーがそれにアクセスします。
app.use((req, res, next) => { req.customData = 'Some custom data'; next(); }); app.get('/', (req, res) => { res.send(`Data from middleware: ${req.customData}`); });
例) これにより、各ミドルウェアがチェーン内の次のミドルウェアに制御を渡すことができます。
const express = require('express'); const app = express(); app.use((req, res, next) => { console.log('Middleware running for every request.'); next(); });
Express Router は、モジュール型アプリケーションでルートを整理するための優れたツールです。これは、ルートをより小さく管理しやすい部分に分割するのに役立ちます。
例) この例では、ルーターは /users にマウントされており、/users/profile へのリクエストはルーターのルートによって処理されます。
app.use('/users', (req, res, next) => { console.log('Middleware only for /users route.'); next(); });
セッションと Cookie の処理は、ユーザーの認証と状態を管理するために非常に重要です。 Express.js は、セッション データを管理するためのミドルウェアを提供します。
例) Express-session を使用して、セッションを初期化し、ユーザーのセッション全体でアクセスできるセッション データを設定します。
app.get('/users', (req, ress) => { res.send('Fetching all users'); }); app.post('/users', (req, res) => { res.send('Creating a new user'); }); app.put('/users/:id', (req, res) => { res.send(`Updating user with ID: ${req.params.id}`); }); app.delete('/users/:id', (req, res) => { res.send('Deleting user with ID: ${req.params.id}`); });
テンプレート エンジンを使用してビューをレンダリングする場合、変数を渡してコンテンツを動的に生成できます。たとえば、EJS では、レンダリングのために変数をビューに渡すことができます。
例) この例では、タイトル変数とメッセージ変数を EJS テンプレートに渡します。
app.use((req, res, next) => { req.customData = 'Some custom data'; next(); }); app.get('/', (req, res) => { res.send(`Data from middleware: ${req.customData}`); });
EJS は、HTML を記述し、HTML 構造内に JavaScript を直接埋め込むことができる人気のテンプレート エンジンです。シンプルですが強力で、動的 Web ページ用の Express.js とうまく統合されます。
例) 構文は、JavaScript 式を HTML に挿入するために使用されます。
app.use((req, res, next) => { console.log('First middleware'); next(); }); app.use((req, res, next) => { console.log('Second middlware'); });
以上がNode.js と Express.js を使用した Web サイトの構築の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。