twig网页模板基础

2024-05-31 23:38
文章标签 基础 模板 网页 twig

本文主要是介绍twig网页模板基础,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

twig 的tags学习 之一
http://blog.csdn.net/jiaochangyun/article/details/7178372


twig 的tags学习 之二
http://blog.csdn.net/jiaochangyun/article/details/7178896


twig 的tags学习 之三 完结
http://blog.csdn.net/jiaochangyun/article/details/7180037



Twig 是个 简单而强力的模板,因为在学习sf 所以看看她。

本文来源http://twig.sensiolabs.org/doc/tags/index.html


目前支持的tags包括

    for    if    macro    filter    set    extends    block    include    import    from    use    spaceless    autoescape    raw    flush    do

twig在html分为3种

{{...}} 直接输出其中的变量

{#...#} 注释标签

{%...%} 命令标签,就是我们要学习的这些

for标签

这个最简单,就是循环。

基于数组的循环

[html] view plain copy print ?
  1. <h1>Members</h1>  
  2. <ul>  
  3.     {% for user in users %}  
  4.         <li>{{ user.username|e }}</li>  
  5.     {% endfor %}  
  6. </ul>  

基于数字的循环,特别要注意,这里会输出0-10 也就是11个数字。

[html] view plain copy print ?
  1. {% for i in 0..10 %}  
  2.     * {{ i }}  
  3. {% endfor %}  

基于字母的循环

[html] view plain copy print ?
  1. {% for letter in 'a'..'z' %}  
  2.     * {{ letter }}  
  3. {% endfor %}  

在循环体内部的变量

变量名描述
loop.index循环的次数(从1开始)
loop.index0循环的次数(从0开始)
loop.revindex循环剩余次数(最小值为1)
loop.revindex0循环剩余次数(最小值为0)
loop.first当第一次循环的时候返回true
loop.last当最后一次循环的时候返回true
loop.length循环的总数
loop.parent被循环的数组
loop.length loop.revindex loop.revindex0 , loop.last  这几个值只有在被循环的是 php数组 或实现了 Countable  接口的类,才有效。

添加一个条件

跟PHP不一样,在循环内部不支持break和continue语句,你只能通过过滤器去跳过一些循环,就像这样

[html] view plain copy print ?
  1. <ul>  
  2.     {% for user in users if user.active %}  
  3.         <li>{{ user.username|e }}</li>  
  4.     {% endfor %}  
  5. </ul>  

else 分支

如果 users是个空数组就会输出no user found 。

[html] view plain copy print ?
  1. <ul>  
  2.     {% for user in users %}  
  3.         <li>{{ user.username}}</li>  
  4.     {% else %}  
  5.         <li><em>no user found</em></li>  
  6.     {% endfor %}  
  7. </ul>  


按keys循环

[html] view plain copy print ?
  1. <h1>Members</h1>  
  2. <ul>  
  3.     {% for key in users|keys %}  
  4.         <li>{{ key }}</li>  
  5.     {% endfor %}  
  6. </ul>  

按keys, values循环

[html] view plain copy print ?
  1. <h1>Members</h1>  
  2. <ul>  
  3.     {% for key, user in users %}  
  4.         <li>{{ key }}: {{ user.username|e }}</li>  
  5.     {% endfor %}  
  6. </ul>  


if标签

这个不用多说,直接看例子
[html] view plain copy print ?
  1. {% if users %}  
  2.     <ul>  
  3.         {% for user in users %}  
  4.             <li>{{ user.username|e }}</li>  
  5.         {% endfor %}  
  6.     </ul>  
  7. {% endif %}  
  8.   
  9. {% if kenny.sick %}  
  10.     Kenny is sick.  
  11. {% elseif kenny.dead %}  
  12.     You killed Kenny!  You bastard!!!  
  13. {% else %}  
  14.     Kenny looks okay --- so far  
  15. {% endif %}  

macro标签

macro(宏标签)类似于其他语言中的函数,常用于填充html标签,以下是一个例子,用来渲染<input>

[html] view plain copy print ?
  1. {% macro input(name, value, type, size) %}  
  2.     <input type="{{ type|default('text') }}" name="{{ name }}" value="{{ value|e }}" size="{{ size|default(20) }}" />  
  3. {% endmacro %}  

macro与函数的不同之处在于:

1、参数的默认值是通过macro块内部的 default过滤器来定义的。

2、参数总是可选的。

另外,就跟php函数一样,macro内部是无法使用外部的变量的。但你可以传递一个特殊变量_context作为参数来获取整个内容。

macro可以被定义在任何的模板内,但在你使用之前需要使用 imported

[html] view plain copy print ?
  1. {% import "forms.html" as forms %}  
然后就可以这样使用了

[html] view plain copy print ?
  1. <p>{{ forms.input('username') }}</p>  
  2. <p>{{ forms.input('password', null, 'password') }}</p>  
如果你要在定义macro的模板里使用,就不需要imported 可以使用特殊变量_self

[html] view plain copy print ?
  1. <p>{{ _self.input('username') }}</p>  

如果你要定义一个macro里 包含另一个macro,并且两个macro在同一个文件里,可以使用特殊变量_self

[html] view plain copy print ?
  1. {% macro input(name, value, type, size) %}  
  2.   <input type="{{ type|default('text') }}" name="{{ name }}" value="{{ value|e }}" size="{{ size|default(20) }}" />  
  3. {% endmacro %}  
  4.   
  5. {% macro wrapped_input(name, value, type, size) %}  
  6.     <div class="field">  
  7.         {{ _self.input(name, value, type, size) }}  
  8.     </div>  
  9. {% endmacro %}  

如果两个macro在不同的文件里,你需要使用import

[html] view plain copy print ?
  1. {# forms.html #}  
  2.   
  3. {% macro input(name, value, type, size) %}  
  4.   <input type="{{ type|default('text') }}" name="{{ name }}" value="{{ value|e }}" size="{{ size|default(20) }}" />  
  5. {% endmacro %}  
  6.   
  7. {# shortcuts.html #}  
  8.   
  9. {% macro wrapped_input(name, value, type, size) %}  
  10.     {% import "forms.html" as forms %}  
  11.     <div class="field">  
  12.         {{ forms.input(name, value, type, size) }}  
  13.     </div>  
  14. {% endmacro %}  

filter标签

就是给整个区块使用过滤器

[html] view plain copy print ?
  1. {% filter upper %}  
  2.     This text becomes uppercase  
  3. {% endfilter %}  

[html] view plain copy print ?
  1. {% filter lower|escape %}  
  2.     <strong>SOME TEXT</strong>  
  3. {% endfilter %}  

这篇关于twig网页模板基础的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1019373

相关文章

0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型的操作流程

《0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeekR1模型的操作流程》DeepSeekR1模型凭借其强大的自然语言处理能力,在未来具有广阔的应用前景,有望在多个领域发... 目录0基础租个硬件玩deepseek,蓝耘元生代智算云|本地部署DeepSeek R1模型,3步搞定一个应

基于Java实现模板填充Word

《基于Java实现模板填充Word》这篇文章主要为大家详细介绍了如何用Java实现按产品经理提供的Word模板填充数据,并以word或pdf形式导出,有需要的小伙伴可以参考一下... Java实现按模板填充wor编程d本文讲解的需求是:我们需要把数据库中的某些数据按照 产品经理提供的 word模板,把数据

MySQL中my.ini文件的基础配置和优化配置方式

《MySQL中my.ini文件的基础配置和优化配置方式》文章讨论了数据库异步同步的优化思路,包括三个主要方面:幂等性、时序和延迟,作者还分享了MySQL配置文件的优化经验,并鼓励读者提供支持... 目录mysql my.ini文件的配置和优化配置优化思路MySQL配置文件优化总结MySQL my.ini文件

网页解析 lxml 库--实战

lxml库使用流程 lxml 是 Python 的第三方解析库,完全使用 Python 语言编写,它对 XPath表达式提供了良好的支 持,因此能够了高效地解析 HTML/XML 文档。本节讲解如何通过 lxml 库解析 HTML 文档。 pip install lxml lxm| 库提供了一个 etree 模块,该模块专门用来解析 HTML/XML 文档,下面来介绍一下 lxml 库

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

uva 1342 欧拉定理(计算几何模板)

题意: 给几个点,把这几个点用直线连起来,求这些直线把平面分成了几个。 解析: 欧拉定理: 顶点数 + 面数 - 边数= 2。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#inc

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <