必知的技术知识:jinjia2基本用法

简介: 必知的技术知识:jinjia2基本用法

前言


这几年一直在it行业里摸爬滚打,一路走来,不少总结了一些python行业里的高频面试,看到大部分初入行的新鲜血液,还在为各样的面试题答案或收录有各种困难问题


于是乎,我自己开发了一款面试宝典,希望能帮到大家,也希望有更多的Python新人真正加入从事到这个行业里,让python火不只是停留在广告上。


或可关注原创个人博客:


JinJa2模版语法


Jinja 2 默认配置如下:


所有扩展名为 .html 、 .htm 、 .xml 以及 .xhtml 的模板会开启自动转义


模板可以利用 {% autoescape %} 标签选择自动转义的开关。


Flask 在 Jinja2 上下文中插入了几个全局函数和助手,另外还有一些目前默认的值


于django的模版语言template类似,但是更强大,还可以支持函数传递,模版中的函数调用,并且传递参数等


...


return render_template("index.html", double=lambda x : x * 2)


1


2


{ { double(2) }}


{ { (".").join(【"a","b","c"】) }}


1


2


模版变量


{ {}}: 来表示变量名


Jinja2 模版中的变量代码块可以是任意 Python 类型或者对象,只要它能够被 Python 的 str() 方法转换为一个字符串就可以


比如,可以通过下面的方式显示一个字典或者列表中的某个元素


{ { object【'key'】 }}


{ { object.key }}


{ { object【0】 }}


1


2


3


模版控制


{% %}: 定义的控制代码块,可以实现一些语言层次的功能,比如循环或者if语句,类似django的模版语言哦


{% if 条件1 %}


语句块1


{% elif 条件2 %}


语句块2


{% else %}


不符合所有条件


{% endif %}


1


2


3


4


5


6


7


{% for index in indexs if index!=1 %}


{ { index }}


{% endfor %}


1


2


3


过滤器


过滤器的本质就是函数。有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化、运算等等,那么这就用到了过滤器


{ { object | filter}}


1


字符串过滤器


过滤器 说明


safe 禁止转义,渲染时不会转义特殊字符


capitallize 把首字母转大写,其他的字母转小写


lower 把所有的字母转小写


upper 把所有字母转大写


title 把每个单词的首字母转大写


trim 去掉首尾空格


striptags 去掉所有的HTML标签


join 将多个值拼接成字符串,类似python的join()函数


replace 替换字符串的值


round 对数字四舍五入


int 转换成int类型


列表过滤器


过滤器 说明


first 获取列表的第一个元素


last 获取列表的最后一个


sort 排序列表


sum 列表求和


length 列表的长度


模版上下文


下面的全局变量默认在 //代码效果参考:http://www.jhylw.com.cn/544426613.html

Jinja2 模板中可用:

config


当前的配置对象 (flask.config)0.6 新版功能.在 0.10 版更改: 现在这总是可用的,甚至在导入的模版里。


request


当前的请求对象 (flask.request)。当模版不是在活动的请求上下文中渲染时这个变量不可用。


session


当前的会话对象 (flask.session)。当模版不是在活动的请求上下文中渲染时这个变量不可用。


g


请求相关的全局变量 (flask.g)。当模版不是在活动的请求上下文中渲染时这个变量不可用。


url_for()


flask.url_for() 函数


get_flashed_messages()


flask.get_flashed_messages() 函数


自动转义


自动转义的概念是自动转义特殊字符。 HTML (或 XML ,因此也有 XHTML )意义下的特殊字符是 & , > , < , " 以及 '


因为这些字符在文档中表示它们特定的含义,如果你想在文本中使用它们,应该把它们替换成相应的“实体”。不这么做不仅会导致用户疲于在文本中使用这些字符,也会导致安全问题。 (见 跨站脚本攻击(XSS) )


虽然你有时会需要在模板中禁用自动转义,比如在页面中显式地插入 HTML , 可以是一个来自于 markdown 到 HTML 转换器的安全输出


我们有三种可行的解决方案:


在传递到模板之前,用 Markup 对象封装 HTML字符串。一般推荐这个方法


在模板中,使用 |safe 过滤器显式地标记一个字符串为安全的 HTML ( { { myvariable|safe }} )


临时地完全禁用自动转义系统


在模板中禁用自动转义系统,可以使用 {%autoescape %}


{% autoescape false %}


autoescaping is disabled here


{ { will_not_be_escaped }}


{% endautoescape %


1


2


3


4


自定义过滤器


如果你要在 Jinja2 中注册你自己的过滤器,你有两种方法。你可以把它们手动添加到应用的 jinja_env 或者使用 template_filter() 装饰器。


下面两个例子作用相同,都是反转一个对象


@app.template_filter('reverse')


def reverse_filter(s):


return s【::-1】


def reverse_filter(s):


return s【::-1】


app.jinja_env.filters【'reverse'】 = reverse_filter


1


2


3


4


5


6


7


在使用装饰器的情况下,如果你想以函数名作为过滤器名,参数是可选的。


注册之后, 你可以在模板中像使用 Jinja2 内置过滤器一样使用你的过滤器,例如你在上下文中有一个名为 mylist 的 Python 列表


{% for x in mylist | reverse %}


{% endfor %}


1


2


模版函数


如果你希望在模版中,可以使用一些常用的方法,但是为了不在每个视图都定义一次,那么可以使用template_global将函数注册为模板全局函数


这样在每个模版里都可以很快乐的随意使用了


@app.template_global()


def length(s):


return len(str(s))


1


2


3


使用还是老样子


{ { length("abc") }}


1


模版静态加载


如果希望在模版中加载静态资源,无非两种办法,第一种是使用相对路径


1


第二种是动态获取路径,使用模版提供的url_for方法反向解析到static目录


{ { url_for("static", filename="bootstrap.css") }}


1


JinJa2模版重用


模版宏


宏类似于Python中的函数,宏的作用就是在模板中重复利用代码,避免代码冗余


Jinja2支持宏,还可以导入宏,需要在多处重复使用的模板代码片段可以写入单独的文件,再包含在所有模板中,以避免重复


{% macro %}: 定义个宏


{% macro macro_test(href) %}


这是个宏


这是链接


{% endmacro %}


1


2


3


4


使用宏


{ { macro_test("") }}


1


宏一般会定义为一个html文件,在其他模版中可以导入使用


定义一个测试宏文件macro_input.html


Title


{% macro user_form(username,password) %}


{% endmacro %}


1


2


3


4


5


6


7


8


9


10


11


12


13


14


使用这个宏文件


{% import 'macro_input.html' as macro_input %}


{ { macro_input.user_form("admin","123456") }}


1


2


模版继承


模板继承是为了重用模板中的公共内容


一般Web开发中,继承主要使用在网站的顶部菜单、底部。这些内容可以定义在父模板中,子模板直接继承,而不需要重复书写


{% block %}标签定义的内容,相当于在父模板中挖个坑,当子模板继承父模板时,可以进行填充


父模版


{% block top %}


顶部菜单 导入一系列css样式等


{% endblock top %}


{% block content %}


内容


{% endblock content %}


{% block bottom %}


底部 导入一系列js等


{% endblock bottom %}


1


2


3


4


5


6


7


8


9


10


11


子模版,使用{% extends %}标签引入父模版


{% extends 'base.html' %}


{% block content %}


需要填充的内容


{% endblock content %}


1


2


3


4


注意


不支持多继承


为了便于阅读,在子模板中使用extends时,尽量写在模板的第一行


不能在一个模板文件中定义多个相同名字的block标签


当在页面中使用多个block标签时,建议给结束标签起个名字,当多个block嵌套时,阅读性更好


模版包含


Jinja2模板中,除了宏和继承,还支持一种代码重用的功能,叫包含{% include %}


它的功能是将另一个模板整个加载到当前模板中,并直接渲染


包含在使用时,如果包含的模板文件不存在时,程序会抛出TemplateNotFound异常,可以加上ignore missing关键字


如果包含的模板文件不存在,会忽略这条include语句


{% include 'index.html' ignore missing %}


1


宏(Macro)、继承(Block)、包含(include)均能实现代码的复用。


继承(Block)的本质是代码替换,一般用来实现多个页面中重复不变的区域。


宏(Macro)的功能类似函数,可以传入参数,需要定义、调用。


包含(include)是直接将目标模板文件整个渲染出来。

相关文章
|
3月前
|
SQL 安全 Shell
vulnhub靶机实战_DC-3
本文介绍DC-3靶机渗透测试全过程,涵盖环境搭建、信息扫描、SQL注入、权限提升等环节。通过Joomla漏洞获取管理员密码,上传木马并提权至root,最终获取flag,是一套完整的渗透实战流程。
828 1
|
7月前
|
SQL 数据库 开发者
Python中使用Flask-SQLAlchemy对数据库的增删改查简明示例
这样我们就对Flask-SQLAlchemy进行了一次简明扼要的旅程,阐述了如何定义模型,如何创建表,以及如何进行基本的数据库操作。希望你在阅读后能对Flask-SQLAlchemy有更深入的理解,这将为你在Python世界中从事数据库相关工作提供极大的便利。
693 77
|
7月前
|
人工智能 Java API
MCP客户端调用看这一篇就够了(Java版)
本文详细介绍了MCP(Model Context Protocol)客户端的开发方法,包括在没有MCP时的痛点、MCP的作用以及如何通过Spring-AI框架和原生SDK调用MCP服务。文章首先分析了MCP协议的必要性,接着分别讲解了Spring-AI框架和自研SDK的使用方式,涵盖配置LLM接口、工具注入、动态封装工具等步骤,并提供了代码示例。此外,还记录了开发过程中遇到的问题及解决办法,如版本冲突、服务连接超时等。最后,文章探讨了框架与原生SDK的选择,认为框架适合快速构建应用,而原生SDK更适合平台级开发,强调了两者结合使用的价值。
10588 33
MCP客户端调用看这一篇就够了(Java版)
|
5月前
|
机器学习/深度学习 人工智能 API
一篇说人话的文章,告诉你 Django、Flask、FastAPI 到底怎么选
Django 是功能齐全的“全家桶”,适合快速搭建完整应用;Flask 灵活轻量,适合小型项目与自定义开发;FastAPI 性能强劲,专为高并发与 API 设计。三者定位不同,适用场景各异,学习顺序建议:FastAPI → Django,提升开发效率与理解深度。
398 10
|
Linux Python
Python- jinja2模块详解
Python- jinja2模块详解
1274 1
|
自然语言处理 索引 Python
详解模板渲染引擎 jinja2
详解模板渲染引擎 jinja2
1125 10
|
JavaScript 数据库 Python
一篇文章搞懂flask_sqlalchemy常用操作
这篇文章介绍了Flask框架中SQLAlchemy库的常用操作,包括查询、删除和更新数据的方法和技巧。
902 3
|
Docker Python Windows
pycharm使用fastapi/uvicorn无法reload的问题
这篇文章讨论了在PyCharm中使用FastAPI和uvicorn时遇到的无法快速重载的问题,并提供了包括降级uvicorn版本和使用命令行运行等解决方法。
pycharm使用fastapi/uvicorn无法reload的问题
|
存储 人工智能 自然语言处理
无缝融入,即刻智能[二]:Dify-LLM平台(聊天智能助手、AI工作流)快速使用指南,42K+星标见证专属智能方案
【8月更文挑战第8天】无缝融入,即刻智能[二]:Dify-LLM平台(聊天智能助手、AI工作流)快速使用指南,42K+星标见证专属智能方案
无缝融入,即刻智能[二]:Dify-LLM平台(聊天智能助手、AI工作流)快速使用指南,42K+星标见证专属智能方案
|
数据处理 开发者 UED
FastAPI 的模板引擎简直太神奇啦!这就是构建动态 Web 页面的终极秘籍,快来一探究竟!
【8月更文挑战第31天】FastAPI 是一款高性能异步 Web 框架,可通过集成模板引擎(如 Jinja2 或 Mako)实现动态页面渲染。使用模板引擎可分离页面结构与数据,简化代码并提升可维护性。此外,它还提供丰富的语法支持,如循环和条件判断,从而增强页面展示效果及开发效率。通过简单的配置步骤,即可在 FastAPI 中启用模板引擎,显著改善用户体验。
1366 1