New Syntax
Bazı insanlar alışkanlık kabul ediyorum, ama ben "için ... else" dal kullanarak oldum yana sağ hissediyor. Bu çok olmayabilir, ama bu biraz temiz benim şablonları tutar.
{% for row in articles %}
Display articles ...
{% else %}
No articles.
{% endfor %}
Automatic Escaping
Sen motor şablonu otomatik olarak herhangi bir çıkış kaçış olabilir. Artık her yerde ... htmlspecialchars tekrarlamak zorunda gibi bu harika. Dal güzel yapar.
{% autoescape on %}
Everything will be automatically escaped in this block
{% endautoescape %}
Template Inheritance
Sevdiğim diğer bir özelliği baz şablonlar genişletmek için yeteneğidir. Burada temel bir örnek
base.html template
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN">
<html lang="en">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
{% block head %}
<link rel="stylesheet" href="style.css" />
<title>{% block title %}{% endblock %} - My Webpage</title>
{% endblock %}
</head>
<body>
<div id="content">{% block content %}{% endblock %}</div>
<div id="footer">
{% block footer %}
© Copyright 2009 by <a href="http://domain.invalid/">you</a>.
{% endblock %}
</div>
</body>
child.html template
{% extends "base.html" %}
{% block title %}Index{% endblock %}
{% block head %}
{% parent %}
<style type="text/css">
.important { color: #336699; }
</style>
{% endblock %}
{% block content %}
<h1>Index</h1>
<p class="important">
Welcome on my awesome homepage.
</p>
{% endblock %}
Bir çocuk şablon vb sayfa belirli stilleri, içerik, için blokları kılabilirsiniz ... Ayrıca baskın sırasında bunu tüm kaybetmek yok bu yüzden anne içeriğini kapmak {% ebeveyn%} kullanımını fark edebilirsiniz.
Sana Twig bir gitmek vermek öneririz. Son derece yararlı.