Templateでのシンタックス
ViewからTemplateに値を渡して表示する方法がわかったら、次はその渡された値からHTMLを切り替えたり、列挙された値の取り出しをしてみます。
まずは views.py を編集します。今回は色々な値を設定します。
# vim:fileencoding=utf-8
from django.shortcuts import render_to_response
def first(request):
from datetime import datetime
return render_to_response('first.html', {
'abc': u'abcですと!',
'none_data': None,
'empty_string': '',
'two_value': 2,
})マルチバイト文字列が入っているので、ファイル保存時にUTF-8にすること。
それと、先頭にファイルの文字コードを示すコメントが入っている点に注意してください。
続いて、first.htmlを書き換えます。
<html>
<head>
</head>
<body>
<p>サンプルアプリケーション はじめの一歩</p>
{% if none_data %}
<p>None値はこっちには入らない。</p>
{% else %}
<p>none_dataは Noneです</p>
{% endif %}
{% if emtpy_data %}
<p>empty_data は空文字列なのでこっちに入ります。</p>
{% else %}
<p>empty_data はこっちに入ります。</p>
{% endif %}
<p>
{% for ch in abc %}
<span>{{ ch }}</span>
{% endfor %}
</p>
{% ifequal two_value 2 %}
<p>two_value は 2 なので表示される。</p>
{% endifequal %}
{% ifnotequal two_value 1 %}
<p>two_value は 1 ではないので表示される。</p>
{% endifnotequal %}
</body>
</html>ブラウザでアクセスするとHTMLは以下のようになります。
(余分な改行を一部けずっています。)
<html> <head> </head> <body> <p>サンプルアプリケーション はじめの一歩</p> <p>none_dataは Noneです</p> <p>empty_data はこっちに入ります。</p> <p> <span>a</span> <span>b</span> <span>c</span> <span>で</span> <span>す</span> <span>と</span> <span>!</span> </p> <p>two_value は 2 なので表示される。</p> <p>two_value は 1 ではないので表示される。</p> </body> </html>
DjangoのTemplateでは、シンタックスというか制御文が入るところには、{% %}というタグを使用します。forで値を取り出すときも、Pythonのfor文に近い形で実装がされているため、"abcですと!"という部分は簡単に1文字ずつ処理できます。
その反面、凄く不便に感じるのが if の制御で比較演算子が一切使用できないことです。== はもちろん > とか < など全く使用できません。その代わりにサンプルコードでも使用している ifequal ifnotequal がありますが、細かい制御は Templateファイルがひたすら複雑になったりします。
Djangoでは、極力 Viewで表示用の処理を済ませてしまったり、Model側に表示用の関数を持たせることで、Templateに複雑なロジックを入れないのが良いと思います。ちなみに Templateでも引数無しの関数であれば、呼び出すことは可能です。
Templateで使用できる if や for は、組み込みタグとして分類されています。詳しくは Djangoのリファレンスを参照してください。(日本語訳は、1.0のマニュアルなので少し古いですが。。。)
次は、フィルターを使って表示する値をごにょごにょしてみたいと思います。