{% %} 在 html 中是什么意思 [已关闭]

2022-08-30 14:00:48

我认为它用于引用php的东西,但我不确定。我在html文件中看到其中一些是这样写的:

{% if ban.reason %}
    <p class="reason">
        {{ ban.reason }}
    </p>
{% endif %}

答案 1

这是一个模板引擎系统,它的语法基于 jinja。另一个代码示例:

{% extends "layout.html" %}

{% block body %}
    <ul>
        {% for user in users %}
            <li><a href="{{ user.url }}">{{ user.username }}</a></li>
        {% endfor %}
    </ul>
{% endblock %}

来自维基百科:

使用模板引擎的好处包括:

  • 鼓励将源代码组织到操作上不同的层中(参见例如MVC)
  • 通过减少不必要的再生产来提高生产率
  • 通过允许基于技能组合(例如,艺术与技术)的工作分离来增强团队合作

典型特点

模板引擎通常包括大多数高级编程语言通用的功能,重点是处理纯文本的功能。这些功能包括:
  • 变量和函数
  • 文本替换
  • 文件包含(或包含)
  • 条件评估和循环

(完自维基百科)


PHP有几个模板引擎。其中之一是[**Twig**](http://twig.sensiolabs.org/)。

例如,与其这样写:

<?php echo $var ?>
<?php echo htmlspecialchars($var, ENT_QUOTES, 'UTF-8') ?>

你可以用Twig做到这一点:

{{ var }}
{{ var|escape }}

另一个例子:

<ul id="navigation">
    <?php if (navigation) { ?>
        <?php foreach ($navigation as $item) { ?>
            <li><a href="<?php echo $item->href; ?>"><?php echo $item->caption; ?></a></li>
        <?php } ?>
    <?php } ?>
</ul>

在模板引擎中:

<ul id="navigation">
    {% for item in navigation %}
        <li><a href="{{ item.href }}">{{ item.caption }}</a></li>
    {% endfor %}
</ul>

它也可以是像blueimp这样的Javascript模板。另一个代码示例:

<title>{%=o.title%}</title>
<h3><a href="{%=o.url%}">{%=o.title%}</a></h3>
<h4>Features</h4>
<ul>
{% for (var i=0; i<o.features.length; i++) { %}
    <li>{%=o.features[i]%}</li>
{% } %}
</ul>

“o”(小写字母)是对模板函数的数据参数的引用。


答案 2

此语法由读取此文件并生成最终 HTML 的模板引擎使用。其中一些可能是Django或Smarty,就像@karthikr评论的那样。


推荐