当前位置: 首页 > news >正文

jinji2模板

jinjia2模板

jinja2的变量

Jinja2是一个流行的Python模板引擎,用于生成动态HTML页面。在FastAPI中,可以使用Jinja2Templates类来处理动态文件的请求。

from fastapi import FastAPI
import uvicorn
from fastapi.templating import Jinja2Templates
from fastapi import Requestapp=FastAPI()
templates=Jinja2Templates(directory="templates")@app.get("/index")
async def index(request: Request):user = {"name": "liu","age": 18,"gender": "male",}books=["Python基础","FastAPI","数据分析","机器学习","深度学习"]return templates.TemplateResponse("index.html",#模板文件{"request": request,"user": user,"books": books}#context上下文,一个字典)if __name__== '__main__':uvicorn.run("main:app",port=8000,reload=True)

jinja2的过滤器

过滤器用于对变量进行格式化或转换操作,常见的过滤器有**upper(转为大写)、lower(转为小写)、title(转为标题格式)、length(获取长度)、capitalize(首字母大写)、trim(去除空白)、round(四舍五入)**等。用法是在变量后面加上管道符 |,然后跟上过滤器名称。

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Jinja2过滤器示例</title>
</head>
<body><h1>Jinja2过滤器示例</h1><p>原始字符串: {{ user.name }}</p><p>大写: {{ user.name | upper }}</p><p>小写: {{ user.name | lower }}</p><p>标题格式: {{ user.name | title }}</p><p>长度: {{ user.name | length }}</p><p>首字母大写: {{ user.name | capitalize }}</p><p>去除空白: '{{ "   Hello World!   " | trim }}'</p><p>四舍五入: {{ 3.14159 | round(2) }}</p>
</body>
</html>

jinja2的控制结构

1.分支控制

Jinja2提供了**if语句**来实现条件分支控制,可以根据不同的条件渲染不同的内容。

{% if user.age >= 18 %}<p>{{ user.name }}是成年人。</p>
{% else %}<p>{{ user.name }}是未成年人。</p>
{% endif %}
2.循环控制

Jinja2提供了**for语句**来实现循环控制,可以遍历列表或字典等可迭代对象。

<ul>{% for book in books %}<li>{{ book }}</li>{% endfor %}
</ul>

http://www.dtcms.com/a/507077.html

相关文章:

  • Linux route
  • 接10月12日---队列笔记
  • 第四章 串、数组和广义表——课后习题解练【数据结构(c语言版 第2版)】
  • 从C语言标准揭秘C指针:第 10 章:指针与动态内存:堆区内存的生命周期管理
  • 设计汽车网站外贸建站服务器怎么选
  • 微网站制作超链接太原网站开发工程师
  • 服装生产管理系统|基于SpringBoot和Vue的服装生产管理系统(源码+数据库+文档)
  • 牛客101:链表
  • 量化策略中三周期共振策略的仓位管理方法
  • 【python】快速实现pdf批量去除指定位置水印
  • 在 macOS 上用 Docker 为 Java 后端 常见开发需求搭建完整服务(详尽教程)
  • 网站建设翻译网站添加二维码
  • Debug —— Docker配置镜像后下载Mysql等报连接超时
  • 中冶交通建设集团网站发网站视频做啥格式最好
  • 软件定制一条龙整站多关键词优化
  • 【Vscode】显示多个文件 打开多个文件时实现标签栏多行显示
  • vue 技巧与易错
  • vscode编写Markdown文档
  • 使用VScode 插件,连接MySQL,可视化操作数据库
  • 基于微信小程序的公益捐赠安全平台9hp4t247 包含完整开发套件(程序、源码、数据库、调试部署方案及开发环境)系统界面展示及获取方式置于文档末尾,可供参考。
  • 【论文精读】FlowVid:驯服不完美的光流,实现一致的视频到视频合成
  • 【C++】滑动窗口算法习题
  • C语言趣味小游戏----扫雷游戏
  • 三款AI平台部署实战体验:Dify、扣子与BuildingAI深度对比
  • 网站制作难不难小红书搜索优化
  • Python如何使用NumPy对图像进行处理
  • 房产中介网站开发站长工具之家
  • Linux服务器编程实践60-双向管道:socketpair函数的实现与应用场景
  • c++结构体讲解
  • 青岛商城网站建设网站相互推广怎么做