【実践編】Node.js, Express, Pugを使ってWebアプリケーションを開発しよう

2024-07-27

Node.js、Express、Pug で HTML を美しくフォーマットする方法

Pug をインストールする

Pug をインストールするには、次のコマンドを実行します。

npm install pug

Express で Pug を設定する

Express で Pug を使用するように設定するには、以下の手順を行います。

  1. app.engine() メソッドを使用して、Pug エンジンを Express に登録します。
app.engine('pug', require('pug').__express);
  1. app.set() メソッドを使用して、Pug をデフォルトのテンプレート エンジンとして設定します。
app.set('view engine', 'pug');

Pug テンプレートを作成する

Pug テンプレートは .pug 拡張子を持つファイルです。Pug テンプレートの構文は HTML に似ていますが、より簡潔で記述しやすくなっています。

たとえば、次の Pug テンプレートは、<h1> タグと <p> タグを含むシンプルな HTML ページを作成します。

doctype html
html
  head
    title My Website
  body
    h1 My Website
    p This is my website.

Express で Pug テンプレートをレンダリングする

Express で Pug テンプレートをレンダリングするには、res.render() メソッドを使用します。

このメソッドには、テンプレート ファイルの名前と、テンプレートに渡すオプションのデータ オブジェクトを渡します。

たとえば、次のコードは、index.pug テンプレートをレンダリングして、res オブジェクトに送信します。

app.get('/', function (req, res) {
  res.render('index', { title: 'My Website' });
});

このコードは、index.pug テンプレートをレンダリングし、title 変数に My Website という値を設定して、res オブジェクトに送信します。

HTML を整形する

Pug には、HTML を整形するためのいくつかの組み込み機能が用意されています。

たとえば、次のコードは、p タグ内のすべてのテキストを自動的に折り返します。

p This is a long paragraph of text that will be automatically wrapped.

Pug には、他にも多くの機能があります。詳細については、Pug のドキュメント を参照してください。

  • Pug は、HTML をより簡潔で記述しやすくする優れたテンプレート エンジンです。
  • Express と Pug を組み合わせて使用すると、動的かつ見やすい Web アプリケーションを簡単に作成できます。



まず、新しい Node.js プロジェクトを作成する必要があります。これを行うには、次のコマンドを実行します。

npm init -y
npm install express pug

ルート

次に、app.js という名前のファイルを作成し、以下のコードを追加します。

const express = require('express');
const app = express();
const pug = require('pug');

// Pug テンプレートを views ディレクトリに設定する
app.set('views', './views');
app.set('view engine', 'pug');

// データ
const posts = [
  {
    title: 'My First Post',
    content: 'This is my first blog post.'
  },
  {
    title: 'My Second Post',
    content: 'This is my second blog post.'
  }
];

// ルートパス
app.get('/', function (req, res) {
  res.render('index', { posts: posts });
});

// ポート 3000 でサーバーを起動する
app.listen(3000, function () {
  console.log('Server listening on port 3000');
});

このコードは、以下のことを行います。

  • ポート 3000 でサーバーを起動します。
  • index.pug テンプレートをレンダリングし、posts 配列をテンプレートに渡します。
  • / パスへの GET リクエストを処理します。
  • posts という名前の配列を作成し、ブログ記事のデータを含めます。
  • Pug テンプレートを views ディレクトリに設定します。
  • Express と Pug をインストールします。

テンプレート

次に、views ディレクトリに index.pug という名前のファイルを作成し、以下のコードを追加します。

doctype html
html
  head
    title My Blog
  body
    h1 My Blog
    each post in posts
      article
        h2 #{post.title}
        p #{post.content}
  • 各記事には、h2 タグと p タグを使用して、タイトルとコンテンツを表示します。
  • posts 配列をループ処理し、各記事を表示します。
  • My Blog というタイトルの HTML ページを作成します。

実行

このコードを実行するには、次のコマンドを実行します。

node app.js

ブラウザで http://localhost:3000 にアクセスすると、以下のようになります。

My Blog

  • My Second Post This is my second blog post.



カスタム ビュー ヘルパーを作成して、HTML の整形を処理することができます。これは、テンプレート内で複雑なロジックを使用する必要がある場合に役立ちます。

たとえば、次のカスタム ビュー ヘルパーは、テキストを折り返します。

function wrapText(text, width) {
  return text.replace(/.{width}(?=\b)/g, '$0\n');
}

このヘルパーをテンプレートで使用するには、次のようにします。

p= wrapText(post.content, 50)

このコードは、post.content 変数内のテキストを 50 文字の行で折り返します。

Pug ミックスインを使用する

Pug ミックスインを使用して、テンプレート コードを再利用することができます。これは、同じコードを複数のテンプレートで使用する場合に役立ちます。

たとえば、次の Pug ミックスインは、記事カードを作成します。

mixin articleCard(post)
  article
    h2 #{post.title}
    p #{post.content}
each post in posts
  +articleCard(post)

このコードは、posts 配列内の各記事に対して記事カードを生成します。

Pug フィルターを使用する

Pug フィルターを使用して、HTML 出力を処理することができます。これは、テンプレート内で出力をフォーマットする必要がある場合に役立ちます。

たとえば、次の Pug フィルターは、テキストを大文字に変換します。

filter uppercase(text)
  = text.toUpperCase()
p #{post.title | uppercase}

このコードは、post.title 変数内のテキストを大文字に変換します。

Pug テンプレート エンジンオプションを使用する

Pug テンプレート エンジンオプションを使用して、テンプレートのレンダリング方法を制御することができます。

たとえば、pretty オプションを true に設定すると、Pug は HTML 出力を整形します。

app.render('index', { posts: posts }, { pretty: true });

サードパーティ製ライブラリを使用する

HTML を整形するためのサードパーティ製ライブラリをいくつか使用することができます。

たとえば、 は、HTML 出力を整形するためのよく知られたライブラリです。

このライブラリを Express で使用するには、次のようにします。

const htmlBeautifier = require('html-beautifier');

app.get('/', function (req, res) {
  const html = pug.render('index', { posts: posts });
  const formattedHtml = htmlBeautifier.beautify(html);
  res.send(formattedHtml);
});

このコードは、index.pug テンプレートをレンダリングし、posts 配列をテンプレートに渡し、html-beautifier ライブラリを使用して HTML 出力を整形し、整形された HTML をレスポンスとして送信します。


node.js express pug



Node.js入門ガイド

Node. jsは、サーバーサイドのJavaScript実行環境です。つまり、JavaScriptを使ってウェブサーバーやネットワークアプリケーションを開発することができます。Node. js公式サイトからインストーラーをダウンロードします。...


Node.jsのマルチコア活用

Node. jsは、イベント駆動型の非同期I/Oモデルを採用しているため、一般的にシングルスレッドで動作します。これは、CPUの処理能力を最大限に活用するために、ブロックする操作(例えば、ファイルI/Oやネットワーク通信)を非同期的に処理するからです。...


Node.js ファイル書き込み解説

Node. js は、JavaScript をサーバーサイドで実行するためのプラットフォームです。ファイルシステムへのアクセスも可能で、その中でもファイルにデータを書き込む機能は非常に重要です。const fs = require('fs');...


Node.jsでディレクトリ内のファイル一覧を取得する

Node. jsでは、fsモジュールを使用してディレクトリ内のファイル一覧を取得することができます。readdirメソッドは、指定されたディレクトリ内のファイル名とサブディレクトリ名を同期的にまたは非同期的に取得します。同期的な使用注意lstatメソッドはシンボリックリンクのターゲットファイルの情報を取得します。実際のファイルの情報を取得するには、statメソッドを使用します。...


Node.js スタックトレース出力方法

Node. jsでは、エラーが発生した場合にそのエラーのスタックトレースを出力することができます。スタックトレースは、エラーが発生した場所やその原因を特定する上で非常に役立ちます。最も一般的な方法は、エラーオブジェクトの stack プロパティを使用することです。これは、エラーが発生した場所やその呼び出し履歴を文字列として返します。...



SQL SQL SQL SQL Amazon で見る



Node.jsテンプレートエンジンについて

JavaScriptでプログラミングする際、テンプレートエンジンを使用することで、HTMLファイルや他のテキストベースのファイルに動的なコンテンツを埋め込むことができます。Node. jsには、様々なテンプレートエンジンが利用可能です。代表的なテンプレートエンジンには、EJS、Handlebars、Pug(Jade)などがあります。これらのエンジンは、それぞれ異なる構文や機能を持っていますが、基本的には、テンプレートファイルにHTMLの構造を定義し、JavaScriptのコードを使用して動的なデータを埋め込むことができます。


Node.jsでjQueryを使う?

一般的に、jQueryをNode. jsで直接使用することは推奨されません。Node. jsはサーバーサイドでのJavaScript実行を想定しており、ブラウザ環境向けのjQueryの機能は直接利用できないからです。詳細な解説Node. js サーバーサイドでJavaScriptを実行するためのプラットフォームです。ブラウザ環境とは異なり、DOMやブラウザのAPIは直接利用できません。


Node.js の基礎解説

Node. jsは、JavaScriptをサーバーサイドで実行するためのプラットフォームです。つまり、従来ブラウザ上でしか実行できなかったJavaScriptを、サーバー上で実行できるようにする環境を提供します。Node. js JavaScriptを実行するための環境であり、サーバー上で動作します。


Node.js デバッグ入門

Node. js アプリケーションのデバッグは、JavaScript コードのエラーや問題を特定し、解決するためのプロセスです。以下に、一般的なデバッグ手法を日本語で説明します。これを活用して、コードの実行フローを追跡し、問題が発生している箇所を特定します。


Node.js ファイル自動リロード

Node. jsでファイルを自動リロードする方法について、日本語で説明します。最も一般的な方法は、Node. jsのモジュールを使用することです。代表的なモジュールは以下の通りです。supervisor nodemonと同様に、ファイルの変更を検知してプロセスを再起動します。