Leaf¶
Leaf は、Swift にインスパイアされた構文を持つ強力なテンプレート言語です。これを使って、フロントエンドのウェブサイト向けに動的な HTML ページを生成したり、API から送信するリッチなメールを生成したりできます。
Package¶
Leaf を使用する最初のステップは、プロジェクトの SPM パッケージマニフェストファイルに依存関係として追加することです。
// swift-tools-version:5.8
import PackageDescription
let package = Package(
name: "MyApp",
platforms: [
.macOS(.v10_15)
],
dependencies: [
/// Any other dependencies ...
.package(url: "https://github.com/vapor/leaf.git", from: "4.4.0"),
],
targets: [
.target(name: "App", dependencies: [
.product(name: "Leaf", package: "leaf"),
// Any other dependencies
]),
// Other targets
]
)
設定¶
パッケージをプロジェクトに追加したら、Vapor を設定してそれを使用するように構成します。これは通常、configure.swift
で行います。
import Leaf
app.views.use(.leaf)
これにより、コード内で req.view
を呼び出すと、Vapor が LeafRenderer
を使用するように指示します。
Note
Leaf には、ページをレンダリングするための内部キャッシュがあります。Application
の環境が .development
に設定されている場合、このキャッシュは無効になり、テンプレートへの変更が即座に反映されます。.production
やその他の環境では、キャッシュがデフォルトで有効になっており、テンプレートに加えた変更はアプリケーションを再起動するまで反映されません。
Warning
Xcode から実行する際に Leaf がテンプレートを見つけられるようにするためには、 Xcode ワークスペースの custom working directory を設定する必要があります。
フォルダ構成¶
Leaf を設定したら、.leaf
ファイルを格納するための Views
フォルダを用意する必要があります。デフォルトでは、Leaf はプロジェクトのルートに対して ./Resources/Views
というフォルダを要求します。
JavaScript や CSS ファイルを提供する予定がある場合は、Vapor の FileMiddleware
を有効にして、 /Public
フォルダからファイルを提供できるようにすることも可能です。
VaporApp
├── Package.swift
├── Resources
│ ├── Views
│ │ └── hello.leaf
├── Public
│ ├── images (images resources)
│ ├── styles (css resources)
└── Sources
└── ...
Viewのレンダリング¶
Leaf が設定できたので、最初のテンプレートをレンダリングしてみましょう。Resources/Views
フォルダ内に、次の内容で hello.leaf
という新しいファイルを作成します。
Hello, #(name)!
Tip
もし、コードエディタとして VSCode を使用している場合、シンタックスハイライトを有効にするために、Leaf 拡張機能をインストールすることをお勧めします:Leaf HTML
次に、View をレンダリングするルートを登録します。(通常は、routes.swift
やコントローラで行います)
app.get("hello") { req -> EventLoopFuture<View> in
return req.view.render("hello", ["name": "Leaf"])
}
// or
app.get("hello") { req async throws -> View in
return try await req.view.render("hello", ["name": "Leaf"])
}
ここでは、Leaf を直接呼び出すのではなく、Request
の汎用 view
プロパティを使用します。これにより、テスト時に別のレンダラーに切り替えることができます。
ブラウザを開き、/hello
にアクセスしてください。 Hello, Leaf!
と表示されているはずです。これで最初の Leaf ビューのレンダリングが完了です!