Yesod入門 (6) Hamlet: 制御構造やWidgetの埋め込みなど | TECHSCORE BLOG

Yesod入門 (6) Hamlet: 制御構造やWidgetの埋め込みなど

こんにちは、鈴木です。

今回は Yesod の View 周りということで、Hamlet について調べます。

 

制御構造など

$forall

繰り返しをするには $forall を使用します。

まず、繰り返しに使用するための変数 values を Handler で定義します。変数 message は後で使用するので、ついでに定義しています。

View (templates/hello.hamlet) で、変数 values の値を一つずつ表示します。

$if, $elseif, $else

条件分岐をするには $if, $elseif, $else を使用します。

$maybe, $nothing

Maybe 型(Maybe Int とか Maybe String とか)を扱うには $maybe と $nothing を使用します。

lucky が 「Just 777 :: Maybe Int」などであれば「運勢は 777 です。」と表示され、Nothing であれば「運勢を測定できません。」と表示されます。

$case, $of

パターンマッチを行うには $case と $of を使用します。

上記の $maybe, $nothing の例を $case, $of を使用するように書き換えると、以下のようになります。

$with

$with を使用すると式の別名(シノニム)を作ることができます。長い式を何度も使う場合は $with を使用すると良さそうです。

$newline never

ドキュメントには書かれていないようなのですが、「$newline never」と書いておくと HTML 生成時に改行が削除されるようです。

 

変数補間: #{ ... }

変数の値を埋め込むには #{変数名} と記述します。

 

Type-Safe URL: @{ ... }

URL を生成するには @{リソース名} と記述します。

 

Widget の埋め込み: ^{ ... }

Yesod ではテンプレートの中に他のテンプレートを埋め込むことができます。埋め込むことができるパーツのことを Widget と呼びます。

まずは Widget を定義してみます。(Handler/Hello.hs)

次に sampleWidget 用のテンプレート templates/sample-widget.hamlet を作成します。

作成した sampleWidget を埋め込むには、次のように記述します。

 

まとめ

制御構造などは動的なページを生成する場合には必須の機能なので、きちんと把握する必要がありそうです。

他にも $maybe や $case のような Haskell だからこそ必要な機能や、Widget のようなパーツを組み合わせる仕組みがありました。

うまく使いこなせば View まわりの実装が綺麗にできるかもしれません。

 

Comments are closed, but you can leave a trackback: Trackback URL.

Comments

  • kakkun61  On 2016年3月29日 at 09:25

    書かれた当時から変わったのかもしれませんが $with$with var <- exp ですね