在AnQiCMS模板的开发过程中,我们经常需要将不同的文本片段、数字信息甚至是系统变量组合起来,形成一个完整的输出内容,例如构建动态链接、显示格式化的数据或生成用户友好的提示信息。这个过程涉及到字符串和数字变量的拼接,而如何安全、高效地完成这一操作,是模板开发中不可忽视的一环。AnQiCMS强大的模板引擎提供了多种灵活的机制来支持这些需求。

AnQiCMS的模板引擎语法类似Django,变量输出采用双花括号{{ 变量名 }},而控制逻辑如条件判断和循环则使用单花括号与百分号{% 标签 %}。理解这一基本语法是高效开发模板的第一步。

模板中的基本变量输出与自动转义

在AnQiCMS模板中,当我们使用{{ 变量名 }}输出变量时,系统默认会执行“自动转义”(Auto-escaping)。这意味着HTML标签和JavaScript代码等特殊字符会被转换为安全的实体字符,例如<会变成&lt;>会变成&gt;。这一机制是AnQiCMS模板引擎内置的安全措施,旨在有效防止跨站脚本攻击(XSS),确保您的网站内容在展示时不会被恶意注入的代码所破坏。

因此,除非您有明确的理由且对内容的安全性有百分之百的把握,通常不需要额外进行手动转义操作。在多数情况下,直接输出变量即可。

安全地拼接字符串和数字

AnQiCMS提供了多种方式来拼接字符串和数字,让我们逐一了解。

1. 使用 add 过滤器进行简易拼接

最直接、最常用的拼接方式是利用 add 过滤器。这个过滤器非常智能,能够处理多种类型的变量,无论是将字符串与字符串、数字与字符串,还是数字与数字进行相加操作,它都会尝试进行合理的转换和拼接。

使用方法: {{ 变量1|add:变量2 }}

示例: 假设我们有一个文章ID archive.Id 是数字 100,文章标题 archive.Title 是字符串 "AnQiCMS模板教程"

  • 字符串与数字拼接: 如果我们想显示“文章ID: 100”,可以直接这样写:

    {{ "文章ID: "|add:archive.Id }}
    {# 输出: 文章ID: 100 #}
    

    这里,过滤器会自动将数字 100 转换为字符串再与前面的文字拼接。

  • 字符串与字符串拼接: 如果您需要将两个字符串拼接,例如组合文件名:

    {{ "header"|add:".html" }}
    {# 输出: header.html #}
    
  • 数字与数字相加: 当然,add 过滤器也支持纯粹的数字相加操作,例如计算总和:

    {% set price = 50 %}
    {% set quantity = 2 %}
    {{ price|add:quantity }}
    {# 输出: 52 #}
    

add 过滤器在自动转换失败时会忽略无法相加的内容,这增加了它的容错性,但同时也意味着我们需要确保被拼接的变量符合预期。

2. 利用 stringformat 过滤器进行精细化格式输出

当您需要更复杂的格式控制,例如在一段文字中插入多个变量,或者对数字进行特定的格式化(如保留小数位数),stringformat 过滤器是您的得力助手。它类似于编程语言中的printfsprintf函数。

使用方法: {{ "格式字符串"|stringformat:变量1, 变量2, ... }}

格式字符串中可以使用占位符:

  • %s:字符串占位符
  • %d:整数占位符
  • %.2f:浮点数占位符(.2表示保留两位小数)
  • %v:默认格式输出,通常用于复杂类型或不确定类型

示例: 假设我们有 archive.Title"AnQiCMS模板指南"archive.Views1234archive.Price99.95

  • 组合多变量文本:

    {{ "文章标题:%s,浏览量:%d 次。"|stringformat:archive.Title, archive.Views }}
    {# 输出: 文章标题:AnQiCMS模板指南,浏览量:1234 次。 #}
    
  • 格式化数字输出: 如果我们想将价格格式化为两位小数:

    {{ "商品价格:%.2f 元"|stringformat:archive.Price }}
    {# 输出: 商品价格:99.95 元 #}
    
  • 混合多种格式:

    {{ "商品名称:%s,价格:%.2f 元,已售出:%d 件"|stringformat:archive.Title, archive.Price, archive.Views }}
    {# 输出: 商品名称:AnQiCMS模板指南,价格:99.95 元,已售出:1234 件 #}
    

    stringformat 提供了强大的输出控制能力,让您的数据展示更加规范和美观。

3. 处理数字变量的注意事项

虽然AnQiCMS模板引擎在大多数情况下能智能处理变量类型,但在进行复杂的数值运算之前,特别是当变量来源于用户输入或外部数据源,且类型可能不确定时,明确地进行类型转换是一个好的习惯。

  • 直接算术运算:{{ }}中,您可以直接对数字变量进行基本的算术运算:

    {% set num1 = 10 %}
    {% set num2 = 5 %}
    {{ num1 + num2 }} {# 加法 #}
    {{ num1 - num2 }} {# 减法 #}
    {{ num1 * num2 }} {# 乘法 #}
    {{ num1 / num2 }} {# 除法 #}
    {# 输出: 15, 5, 50, 2 #}
    

    这里,如果 num1num2 是可以转换为数字的字符串(例如"10"),模板引擎通常也能正确处理。

  • 显式类型转换:integerfloat 过滤器: 如果一个变量可能是字符串形式的数字,但您需要确保它在运算前是数字类型,可以使用 integerfloat 过滤器:

    {% set str_num = "123" %}
    {{ str_num|integer|add:45 }}
    {# 输出: 168 #}
    
    
    {% set str_price = "99.99" %}
    {{ str_price|float|stringformat:"%.1f" }}
    {# 输出: 99.9 #}
    

    这些过滤器在转换失败时会返回 00.0,因此在实际应用中需要考虑错误处理。

  • 时间戳与日期字符串转换:stampToDate 标签: AnQiCMS中的时间戳通常是数字类型。要将其转换为可读的日期字符串,可以使用 stampToDate 标签:

    {{ stampToDate(archive.CreatedTime, "2006-01-02 15:04") }}
    {# 将10位时间戳格式化为 "年-月-日 时:分" 格式 #}
    

    这里的"2006-01-02 15:04"是Go语言特有的日期格式化基准时间,代表2006年1月2日15点04分,通过它来定义输出的日期格式。

实践中的安全考量

再次强调AnQiCMS模板的自动转义功能是您的安全保障。

  • 默认安全: 只要您使用`{{