Templates with Twig
Easier Than You Think
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
with Margaret Staples
Hello, Nice to Meet You
I'm Margaret
data:image/s3,"s3://crabby-images/12915/12915766d0c7a4eb46b6e1db84bad3ff444276f7" alt=""
data:image/s3,"s3://crabby-images/d9c2b/d9c2bcf66d0b70a7800b7fca5fea42e771a0b7d7" alt=""
data:image/s3,"s3://crabby-images/8e9b0/8e9b0abe5b70e91b56f7cfe60fd006a5c896bd89" alt=""
data:image/s3,"s3://crabby-images/2c5aa/2c5aacbbf98ad083832fe1e238ffc0adaccd64cc" alt=""
data:image/s3,"s3://crabby-images/dd5da/dd5da0a8d2ee37c8fd9949610b91e86d3e436167" alt=""
data:image/s3,"s3://crabby-images/dfe05/dfe05252d7b8bcf2ad05b0811950ecfae9a7807b" alt=""
Hello, Nice to Meet You
I'm Margaret
I have been working with Twig
mostly as part of the Symfony2 framework
for about 3 years
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Hello, Nice to Meet You
I'm Margaret
I'm developing a Social Strategy City-Builder RPG game of awesomeness.
data:image/s3,"s3://crabby-images/4a298/4a2982a53d40a6ad3b278792ba75b0e425196c38" alt=""
brunegame.com
Twig Templates
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Overview
- Create a New Project
- Install Twig
- Create a Twig Layout
- Initial Twig Template
- Using Variables
- Conditionals and Loops
- Including Templates
- Additional Information
Create a New Project
Local Webserver
Linux + Apache + MySQL + PHP
data:image/s3,"s3://crabby-images/2fabb/2fabb695bc36cf69d4dc051fb8fc39985865b3ab" alt=""
data:image/s3,"s3://crabby-images/aa824/aa824745620885897d70029e6d150216df01e9e7" alt=""
Create a New Project
New Project Structure
*/NewProject
*/NewProject/src
*/NewProject/views
*/NewProject/index.php
*/path/to/web/directory
data:image/s3,"s3://crabby-images/2fabb/2fabb695bc36cf69d4dc051fb8fc39985865b3ab" alt=""
data:image/s3,"s3://crabby-images/aa824/aa824745620885897d70029e6d150216df01e9e7" alt=""
Install Twig
Composer
Dependency Manager for PHP
data:image/s3,"s3://crabby-images/4a3fb/4a3fb1e12aafebf2fab8b5fd628aa665ed511dc9" alt=""
getcomposer.org
Install Twig
Install Twig
*/NewProject/composer.json
{
"autoload": {
"psr-4": {
"NewProject\\Classes\\": "src/"
}
},
"require": {
"twig/twig": "~1.0"
}
}
> php composer.phar install
data:image/s3,"s3://crabby-images/4a3fb/4a3fb1e12aafebf2fab8b5fd628aa665ed511dc9" alt=""
Install Twig
Install Twig (Alternative)
> php composer.phar init
Search for a package: Twig
Enter package # to add ...: 0
...
"autoload": {
"psr-4": {
"NewProject\\Classes\\": "src/"
}
}
...
data:image/s3,"s3://crabby-images/4a3fb/4a3fb1e12aafebf2fab8b5fd628aa665ed511dc9" alt=""
Install Twig
*/NewProject/index.php
<?php
require_once 'vendor/autoload.php';
require_once 'vendor/twig/twig/lib/Twig/Autoloader.php';
Twig_Autoloader::register();
$loader = new Twig_Loader_Filesystem('views');
$twig = new Twig_Environment($loader, [
'cache' => 'cache',
]);
Add to index.php
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Create a Twig Layout
*/NewProject/views/layout.html
<!DOCTYPE html>
<html>
<head>
<style>
h1 {
color: blue;
}
</style>
</head>
<body>
</body>
</html>
Create layout.html
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Create a Twig Layout
Add Blocks to the Layout
Create layout.html
...
<body>
{% block content %}
{% endblock %}
{% block footer %}
© Copyright 2015 by MyCompany.
{% endblock %}
</body>
...
Blocks designate areas that may be replaced by child templates.
Block content in the layout will be the default.
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Initial Twig Template
*/NewProject/views/index.html
{% extends 'layout.html' %}
{% block content %}
<h1>Hello World!</h1>
{% endblock %}
Create index.html
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Initial Twig Template
*/NewProject/src/Page.php
<?php
namespace NewProject\Classes;
class Page
{
public function index()
{
return [
'salute' => 'goodnight',
'target' => 'moon'
];
Create Page.php
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Initial Twig Template
*/NewProject/index.php
<?php
...
use NewProject\Classes\Page;
...
$page = new Page();
echo $twig->render('index.html', $page->index());
Use Page.php and index.html
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Initial Twig Template
localhost/NewProject/index.php
View Initial Twig Template
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Hello World!
Let's Review!
What is the purpose of views/layout.html?
Provide HTML, CSS, and Javascript that is the same for multiple templates
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Let's Review!
What is the purpose of Page.php's index() function?
To prepare data for the index.html template.
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Let's Review!
To identify where in layout.html to place the template content.
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
What is the purpose of the
{% content block %} {% endblock %} tags?
Using Variables
Use variables from Page.php index()
*/NewProject/src/Page.php
return [
'salute' => 'goodnight',
'target' => 'moon'
];
*/NewProject/index.php
echo $twig->render('index.html', $page->index());
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Using Variables
*/NewProject/views/index.html
{% extends 'layout.html' %}
{% block content %}
<h1>{{ salute }} {{ target }}!</h1>
{% endblock %}
Use variables from Page.php index()
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Using Variables
View Your Page
localhost/NewProject/index.php
goodnight moon!
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Using Variables
Modify Your Variables
*/NewProject/views/index.html
{% extends 'layout.html' %}
{% block content %}
<h1>{{ salute|title }} {{ target|title }}!</h1>
{% endblock %}
Goodnight Moon!
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
Using Variables
{{ salute|capitalize }} = Goodnight
{{ salute|lower }} = goodnight
{{ salute|upper }} = GOODNIGHT
{{ salute }} moon = goodnight moon
{{ salute ~ ' ' ~ target }} = goodnight moon
{{ "goodnight ${target}" }} = goodnight moon
{{ "hi moon"|replace({ 'hi': 'goodnight' }) }} = goodnight moon
data:image/s3,"s3://crabby-images/7ed53/7ed5313fa219c352432ccf136f9c7ca6496d81a2" alt=""
Strings
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
twig.sensiolabs.org
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
Using Variables
{{ -1234.567|round }} = -1235
{{ -1234.567|abs }} = 1234.567
{{ "1 + 2 = ${1 + 2}" }} = 1 + 2 = 3
{{ -1234.567|number_format(2) }} = -1,234.56
{{ 5 // 2 }} = 2
{{ 2 ** 3 }} = 8
data:image/s3,"s3://crabby-images/7ed53/7ed5313fa219c352432ccf136f9c7ca6496d81a2" alt=""
Numbers
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
twig.sensiolabs.org
Using Variables
data:image/s3,"s3://crabby-images/7ed53/7ed5313fa219c352432ccf136f9c7ca6496d81a2" alt=""
Setting Variables
twig.sensiolabs.org
{% set my_var = "I am a new value!" %}
{{ my_var }}
I am a new value!
Using Variables
More Filters
twig.sensiolabs.org/doc/filters/index.html
trim upper url_encodereplace reverse round nl2br number_format convert_encoding date |
abs batch capitalize date_modify default escape first formatjoin json_encode |
keys last length lower merge rawslice sort split striptags |
---|
Using Variables
Custom Filters, Functions, and Tags
twig.sensiolabs.org/doc/advanced.html#creating-an-extension
Implement the Twig_ExtensionInterface Interface
Register using the addExtension() method
Override the getFilters() method
Register functions using the getFunctions() method
Override the getTokenParsers() method
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
Let's Review!
How do we print the value of a variable in Twig?
Surround the variable name with double curly brackets:
{{ foo }}
data:image/s3,"s3://crabby-images/98a89/98a89b9acb250d1a5aef48990ba35fdfc7ec230e" alt=""
Let's Review!
How do we apply a Twig filter to a value?
Follow the value with a pipe and the name of the filter:
{{ foo|title }}
data:image/s3,"s3://crabby-images/98a89/98a89b9acb250d1a5aef48990ba35fdfc7ec230e" alt=""
Let's Review!
What signifies an action tag as opposed to a display tag?
Surround the action with curly-bracket percent-sign pairs:
{% set foo = bar %}
data:image/s3,"s3://crabby-images/98a89/98a89b9acb250d1a5aef48990ba35fdfc7ec230e" alt=""
Conditionals and Loops
Logic
{{ "goodnight" starts with "g" }} = true
{{ "moon" ends with "p" }} = false
{{ "night" in "goodnight" }} = true
{{ 1 in [ 1, 2, 3 ] }} = true
{{ 1 is even }} = false
{{ 4 not in [ 1, 2, 3 ] }} = true
{{ "moon"|length < 3 }} = false
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
data:image/s3,"s3://crabby-images/4d591/4d591c31a6ec042abf29ab0a526a0359f0e0ff36" alt=""
twig.sensiolabs.org
data:image/s3,"s3://crabby-images/7ed53/7ed5313fa219c352432ccf136f9c7ca6496d81a2" alt=""
Conditionals and Loops
Conditionals
*/NewProject/views/index.html
{% if target|lower == 'sun' %}
{% set title_color = 'red' %}
{% else %}
{% set title_color = 'purple' %}
{% endif %}
<h1 style="color:{{ title_color }}">
{{ salute|title }} {{ target }}!
</h1>
data:image/s3,"s3://crabby-images/7ed53/7ed5313fa219c352432ccf136f9c7ca6496d81a2" alt=""
Goodnight Moon!
Conditionals and Loops
Loops
*/NewProject/src/Page.php
public function index()
{
return [
'salute' => 'Goodnight',
'my_set' => [
'red' => 'Sun',
'blue' => 'Moon',
'purple' => 'Stars'
]
];
}
data:image/s3,"s3://crabby-images/7ed53/7ed5313fa219c352432ccf136f9c7ca6496d81a2" alt=""
Conditionals and Loops
Loops
*/NewProject/views/index.html
{% for key,value in my_set %}
<h1 style="color: {{ key }}">
{{ loop.index }}. {{ salute }} {{ value }}!
</h1>
{% endfor %}
1. Goodnight Sun!
2. Goodnight Moon!
3. Goodnight Stars!
data:image/s3,"s3://crabby-images/0a164/0a164237cb841d3a6715e31ef186a251216b5ce7" alt=""
Conditionals and Loops
Loops with Objects
class MyRecord
{
protected title;
protected description;
protected link;
protected color;
...
}
data:image/s3,"s3://crabby-images/0a164/0a164237cb841d3a6715e31ef186a251216b5ce7" alt=""
Conditionals and Loops
Loops with Objects
*/NewProject/views/index.php
{% for record in my_records %}
<a href="{{ record.link }}">
<h1 style="color: {{ record.color }}">
{{ record.title }}
</h1>
</a>
<p>{{ record.description }}</p>
{% endfor %}
data:image/s3,"s3://crabby-images/0a164/0a164237cb841d3a6715e31ef186a251216b5ce7" alt=""
Conditionals and Loops
Loops with Nested Arrays
$my_array = [
1 => [
'title' => "My Title",
'description' => "This is a description",
'link' => "http://twig.sensiolabs.org",
'color' => "blue"
],
2 => [
'title' => "Other Title",
'description' => "Another description",
'link' => "http://getcomposer.org",
'color' => "green"
]
];
data:image/s3,"s3://crabby-images/0a164/0a164237cb841d3a6715e31ef186a251216b5ce7" alt=""
Conditionals and Loops
Loops with Nested Arrays
*/NewProject/views/index.php
{% for record in my_records %}
<a href="{{ record.link }}">
<h1 style="color: {{ record.color }}">
{{ record.title }}
</h1>
</a>
<p>{{ record.description }}</p>
{% endfor %}
data:image/s3,"s3://crabby-images/0a164/0a164237cb841d3a6715e31ef186a251216b5ce7" alt=""
Let's Review!
How do we access the keys when looping through an array?
By providing a key name followed by a comma and a value name in the loop declaration:
{% for key,value in array %}
data:image/s3,"s3://crabby-images/c7303/c7303a0bad5747dcc433dfb1757bd72f9733212f" alt=""
Let's Review!
How do we access an object's properties?
By using a dot, followed by the property name:
myObject.objectProperty
*Bracket notation also works: myObject['objectProperty']
data:image/s3,"s3://crabby-images/c7303/c7303a0bad5747dcc433dfb1757bd72f9733212f" alt=""
Let's Review!
How do we access an array value by key?
Just like an object:
myArray.arrayKey
*Bracket notation also works: myArray['arrayKey']
data:image/s3,"s3://crabby-images/c7303/c7303a0bad5747dcc433dfb1757bd72f9733212f" alt=""
Let's Review!
How can we get the current iteration count in a loop?
loop.index
data:image/s3,"s3://crabby-images/c7303/c7303a0bad5747dcc433dfb1757bd72f9733212f" alt=""
Including Templates
Create heading.html
*/NewProject/images/fancyheading.png
*/NewProject/views/heading.html
<div class="heading">
<img src="../images/fancyheading.png">
</div>
data:image/s3,"s3://crabby-images/8d928/8d928abece96788dc116bd4359e0bfc2a0cf8b21" alt=""
Including Templates
Create feature.html
*/NewProject/views/feature.html
<div class="feature">
<img src="../images/feature.png">
</div>
*/NewProject/images/feature.png
data:image/s3,"s3://crabby-images/e3b65/e3b65cbd4dbdfdd69a68aedefb7781ba9102542d" alt=""
Including Templates
Create feature.html
*/NewProject/views/index.html
{% extends 'layout.html' %}
{% block content %}
{% include 'heading.html' %}
<h1>{{ salute|title }} {{ my_set.blue }}!</h1>
{% include 'feature.html' %}
{% endblock %}
Including Templates
localhost/NewProject/index.php
data:image/s3,"s3://crabby-images/8d928/8d928abece96788dc116bd4359e0bfc2a0cf8b21" alt=""
View Your Page
Goodnight Moon!
data:image/s3,"s3://crabby-images/e3b65/e3b65cbd4dbdfdd69a68aedefb7781ba9102542d" alt=""
Twig Templates
Additional Information
data:image/s3,"s3://crabby-images/6644b/6644b8f522a3f500a4a5961f79d22867ba2d7bd6" alt=""
http://twig.sensiolabs.org/
Questions?
Margaret Staples
@dead_lugosi on twitter
deadlugosi on freenode
brunegame.com
Twig
By Margaret Staples
Twig
- 3,743