ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
EJS の include 構文
EJS (Embedded JavaScript Templates) は、Node.js / Express で広く使われるテンプレートエンジンです。ヘッダー・フッター・サイドバーなどの共通パーツを別ファイルに切り出すには include 関数を使います。

基本的な共通化
ディレクトリ構成例
views/
├── partials/
│ ├── header.ejs # ヘッダー
│ ├── footer.ejs # フッター
│ ├── nav.ejs # ナビゲーション
│ └── meta.ejs # メタタグ
├── pages/
│ ├── index.ejs
│ └── about.ejs
└── layout.ejs
views/partials/header.ejs
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<title><%= title %></title>
<link rel="stylesheet" href="/css/style.css">
</head>
<body>
<header>
<h1>マイサイト</h1>
<nav>
<a href="/">Home</a>
<a href="/about">About</a>
</nav>
</header>
<main>
views/partials/footer.ejs
</main>
<footer>
<p>© 2026 My Company</p>
</footer>
</body>
</html>
views/pages/index.ejs
<%- include('../partials/header', { title: 'Top page' }) %>
<h2>Welcome</h2>
<p>これがトップページです。</p>
<%- include('../partials/footer') %>
<%- %> と <%= %> の違い
| 構文 | 動作 | 用途 |
|---|---|---|
<%= var %> | HTML エスケープしてから出力 | ユーザー入力等の表示(XSS 防止) |
<%- var %> | エスケープなしでそのまま出力 | HTML 断片 / include 結果 |
<% code %> | JS 実行のみ、出力なし | if / for / 変数定義 |
<%# %> | コメント | テンプレート内コメント |
include は必ず <%- %>。<%= %> で書くと HTML がエスケープされて <div> のように画面に出てしまいます。
include に変数を渡す
<!-- views/partials/item.ejs -->
<article class="item">
<h3><%= name %></h3>
<p>価格: <%= price %>円</p>
</article>
<!-- 呼び出し側 -->
<% const items = [
{ name: 'りんご', price: 100 },
{ name: 'みかん', price: 80 }
]; %>
<% items.forEach(item => { %>
<%- include('partials/item', { name: item.name, price: item.price }) %>
<% }); %>
親テンプレートで定義された変数は子テンプレートでもそのまま参照可能(EJS 3 系のスコープ仕様)。第 2 引数で明示的に渡すと上書きできます。
パス解決のルール
EJS 3 系で include のパスは現在のファイルからの相対パスです(EJS 2 系の views ルート相対と異なる)。
views/pages/index.ejs から
- '../partials/header' → views/partials/header.ejs
- './sub' → views/pages/sub.ejs
EJS は拡張子を自動で補完:
- 'header' → 'header.ejs'
- 'header.html' → そのまま 'header.html'
絶対パス (/ 始まり) は views ルート扱い
- '/partials/header' → views/partials/header.ejs
Express でのセットアップ
// app.js
const express = require("express");
const path = require("path");
const app = express();
app.set("view engine", "ejs");
app.set("views", path.join(__dirname, "views"));
app.get("/", (req, res) => {
res.render("pages/index", {
title: "Top page",
user: { name: "taro" }
});
});
app.listen(3000);
レイアウト共通化: express-ejs-layouts
毎回 header / footer を include するのが面倒な場合は express-ejs-layouts でレイアウトを自動適用できます:
npm install express-ejs-layouts// app.js
const expressLayouts = require("express-ejs-layouts");
app.use(expressLayouts);
app.set("layout", "layout"); // views/layout.ejs を使用
app.set("layout extractScripts", true);
app.set("layout extractStyles", true);<!-- views/layout.ejs -->
<!DOCTYPE html>
<html>
<head>
<title><%= title %></title>
<%- style %>
</head>
<body>
<%- include('partials/nav') %>
<main>
<%- body %> <!-- ★ 各ページの中身がここに展開 -->
</main>
<%- include('partials/footer') %>
<%- script %>
</body>
</html>
各ページからは render('pages/index') するだけで layout.ejs にラップされます。
他テンプレートエンジンとの比較
| エンジン | 記法 | 共通化 | 特徴 |
|---|---|---|---|
| EJS | <% %> | include | 素の HTML に近い、JS そのまま使える |
| Pug (旧 Jade) | インデント記法 | include / extends / block | 記述量少、独自記法 |
| Handlebars | {{ }} | partials / helper | ロジックレス志向 |
| Mustache | {{ }} | partials | 最小限、複数言語対応 |
| Nunjucks | {% %} | extends / block / include | Jinja2 互換、強力な継承 |
パフォーマンス: キャッシュ
// 本番環境ではテンプレートをコンパイル結果でキャッシュ
app.set("view cache", true); // NODE_ENV=production で自動 ON
// EJS の cache オプション直接指定
const ejs = require("ejs");
ejs.cache = require("ejs").cache; // LRU
Next.js / SSR フレームワークとの関係
近年は Next.js / Nuxt / SvelteKit 等のコンポーネントベース SSR が主流で、EJS のような伝統的サーバサイドテンプレートは新規採用が減っています。ただし:
- 管理画面 / 静的多めのサイトでは今でも EJS / Pug が現役
- Express で軽量なアプリを作る時に最速
- 大量のメールテンプレート、PDF 生成テンプレートでも採用例多数
FAQ
Q: include で Cannot find module
A: パスが現在ファイルからの相対です。../ が必要なケース多数。app.set('views') も再確認。
Q: 親で定義した変数が子で undefined
A: EJS 3 では基本見えますが、Express の res.locals 経由で渡すか、include の第 2 引数で明示的に渡すのが安全。
Q: ループ内 include は遅い?
A: 大量ループでは EJS 関数呼び出しコストが効きます。本番では view cache を ON にし、必要なら HTML を予めビルドしてください。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- インストール
- 値の表示と処理の記述
- テンプレートの共通化(組み込み)
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?