Sanic学习笔记-模板引擎Jinja2集成

Python版本:Python-3.9.4

在线安装Jinja2:

pip3 install sanic-jinja2

离线安装Jinja2:

sanic_jinja2-0.9.1-py3-none-any.whl

Jinja2-2.11.3-py2.py3-none-any.whl

MarkupSafe-1.1.1-cp39-cp39-win_amd64.whl

修改模块配置modules目录下__init__.py

# -*- coding: utf-8 -*-

import sys
from jinja2 import Environment, FileSystemLoader, select_autoescape
from sanic.response import html

"""
所有蓝图name必须添加的地方
"""
__all__ = [
    "user",
    "taobaoke"
]

# 配置模板路径
template_paths = []
for module_name in __all__:
    template_paths.append('./static/templates/' + module_name)


# 配置同步环境
env_sync = Environment(loader=FileSystemLoader(template_paths),
                  autoescape=select_autoescape(['html', 'xml', 'tpl']),
                  enable_async=False)

enable_async_flag = sys.version_info >= (3, 6)

# 配置异步环境
env_async = Environment(loader=FileSystemLoader(template_paths),
                  autoescape=select_autoescape(['html', 'xml', 'tpl']),
                  enable_async=enable_async_flag)


# 同步模板渲染
def template_render_sync(template_file, **kwargs):
    template = env_sync.get_template(template_file)
    rendered_template = template.render(kwargs)
    return html(rendered_template)


# 异步模板渲染
async def template_render_async(template_file, **kwargs):
    template = env_async.get_template(template_file)
    rendered_template = await template.render_async(kwargs)
    return html(rendered_template)

Service代码


                
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Jinja2 是一种流行的 Python 模板引擎,用于生成动态网页和文本文件。它提供了丰富的模板语法,支持变量、表达式、控制语句、过滤器、宏等功能,可以方便、灵活地生成各种格式的输出。下面是一些常用的 Jinja2 模板语法: 1. 输出变量 使用 `{{ variable }}` 语法可以在模板中输出变量的值,例如: ``` Hello, {{ name }}! ``` 这个模板中使用了变量 `name`,它会在渲染时被替换为相应的值。 2. 控制语句 使用 `{% %}` 语法可以在模板中使用控制语句,例如: - `if` 语句:判断条件是否成立,例如: ``` {% if user %} Hello, {{ user }}! {% endif %} ``` - `for` 循环:遍历序列并执行循环体,例如: ``` {% for item in items %} {{ item }} {% endfor %} ``` - `with` 语句:定义变量并限定作用域,例如: ``` {% with title="Hello" %} {{ title }} {% endwith %} ``` 3. 过滤器 使用 `|` 语法可以在模板中应用过滤器,例如: ``` {{ text|truncate(80) }} ``` 这个模板中使用了 `truncate` 过滤器,它可以截断文本并添加省略号,使其不超过 80 个字符。 4. 宏 使用 `{% macro %}` 语法可以在模板中定义宏,例如: ``` {% macro hello(name) %} Hello, {{ name }}! {% endmacro %} ``` 这个模板中定义了一个宏 `hello`,它可以接受一个参数 `name`,并输出相应的问候语。 以上是 Jinja2 的一些常用语法,Jinja2 还提供了更多的语法和功能,可以根据具体需求进行学习和使用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值