本文基于Pebble官方文档, 对pebble的语法做一些介绍. 

===============================
Pebble 官方资料
===============================
主页: https://pebbletemplates.io/
github wiki: https://github.com/PebbleTemplates/pebble/wiki

===============================
Pebble 基本语法
===============================
表达式使用 {{  }} 括起来
{{expression}}

注释使用 {#  #} 括起来
{# This is a comment #}

控制类语句使用 {%  %} 括起来

循环控制, 和python类似, for循环中支持else.

{% for article in articles %}
    <h3>{{ article.title }}</h3>
    <p>{{ article.content }}</p>
{% else %}
   <p>no article yet</p>
{% endfor %}

If 控制

{% if category == "news" %}
    {{ news }}
{% elseif category == "sports" %}
    {{ sports }}
{% else %}
    <p>Please select a category</p>
{% endif %}

变量赋值

{% set header = "Test Page" %}
{{ header }}

===============================
表达式
===============================
简单表达式
{{variable}}
{{obj.property}}

简单函数表达式
{{max(var1, var2) }}

Literals 表达式包括:
    字符串: 使用单引号或双引号括起来.
    true/false: 布尔值
算术表达式, 加减乘除等等
null 或 none : 等同于 Java 的 null
列表集合表达式: [1,2,3] 或 [“one”,”two”]
map集合表达式: {“a”:1,”b”:2}
两个集合包含操作符为:  contains
元素是否集合用:  in
逻辑操作符有:  and , or , not
比较符号有:  > , < 等等
相等符号为:  is

===============================
function
===============================
max()
min()
range(0, 3)
range(0, 6, 2)
0..3 相当于 range(0, 3)

===============================
test 断言
===============================
test 是 pebble 一个非常有特点的概念, 和 is 操作符配合使用, 用来判断表达式是否为真.
is even , 判断是否为偶数
is odd, 判断是否奇数
is null, 判断是否为null
is empty, 判断是否为 empty, 包括的情形有: 对象为null,或字符串变量为””, 或空列表, 或空map等.
is map, 判断表达式是否为map
is iterable, 判断表达式是否可iterable.

===============================
filter
===============================
相比于 function 和 test, filter更经常使用到, 内置的filter有很多, 比如 upper/lower/default 等等,
{{ name || default(‘no value’)}}

slice(fromIndex, toIndex) 的取值效果是[fromIndex, toIndex)
{{ ‘Mitchell’ | slice(1,3) }}

数字格式化
{{ 3.141592653 | numberformat(“#.##”) }}

日期格式化
{{ user.birthday | date(“yyyy-MM-dd”) }}

===============================
表达式的大小写
===============================
顶级variable变量, 其名称大小写敏感, 比如:
{{namE}} 和 {{name}} 是不同的.

属性级的名称, 大小写不敏感, 比如:
{{book.author}} 和 {{book.authoR}} 是效果一样.

对于 {{book.author}} 这样的占位符, Pebble 会智能地匹配下面的方案或屬性:
     book.get(“author”)
     book.getAuthor()
     book.isAuthor()
     book.hasAuthor()
     book.author()
     book.author

===============================
一些特别的tag
===============================
extends tag 用来扩展一个模板
{% extends “base” %}

include 用来将一个模板合并当当前文档中
{% include “advertisement” %}

import 用来将指定模板中的macro引入
{% import “form_util” %}

set 用来定义一个变量
{% set header = “Test Page” %}
{{ header }}

autoescape 用来打开或关闭自动转移, 甚至还可以设定使用何种转义的引擎

{% autoescape false %}
    {{ danger }} {# will not be escaped #}
{% endautoescape %}

verbatim tag 告诉 pebble 不要按照pebble的语法解析tag内的内容, 该功能非常适合和一些 js 前段框架搭配使用.

{% verbatim %}
    {% for user in users %}
        {{ user.name }}
    {% endfor %}}
{% endverbatim %}

macro tag 可以定义一些代码片段, 然后复用这些macro:

{% macro input(type="text", name, value) %}
    <input type="{{ type }}" name="{{ name }}" value="{{ value }}" />
{% endmacro %

{{ input(name="country") }}
{# will output: <input type="text" name="country" value="" /> #}

{% import "form_util" %}
{{ input("text", "country", "Canada") }}

===============================
pebble的扩展性
===============================
pebble 不仅仅使用简单, 而且扩展性非常好, 可以使用java代码编写自己的 filter/function/test, 甚至可以扩展操作符.

选Java后端模板引擎强烈推荐pebble.