当前位置: 代码迷 >> 综合 >> Flask Jinja2 模板
  详细解决方案

Flask Jinja2 模板

热度:91   发布时间:2024-01-11 01:12:50.0

Jinja2模板引擎

模板

视图函数有两个作用:处理业务逻辑和返回响应内容。在大型应用中,把业务逻辑和表现内容放在一起,会增加代码的复杂度和维护成本。本节学到的模板,它的作用即是承担视图函数的另一个作用,即返回响应内容。

  • 模板其实是一个包含响应文本的文件,其中用占位符(变量)表示动态部分,告诉模板引擎其具体的值需要从使用的数据中获取
  • 使用真实值替换变量,再返回最终得到的字符串,这个过程称为“渲染”
  • Flask是使用 Jinja2 这个模板引擎来渲染模板

使用模板的好处:

  • 视图函数只负责业务逻辑和数据处理(业务逻辑方面)
  • 而模板则取到视图函数的数据结果进行展示(视图展示方面)
  • 代码结构清晰,耦合度低

 

 

Jinja2

两个概念:

  • Jinja2:是 Python 被广泛应用的模板引擎,由Python实现的模板语言,他的设计思想来源于 Django 的模板引擎,并扩展了其语法和一系列强大的功能,其是Flask内置的模板语言。
  • 模板语言:是一种被设计来自动生成文档的简单文本格式,在模板语言中,一般都会把一些变量传给模板,替换模板的特定位置上预先定义好的占位变量名。

渲染模版函数

  • Flask提供的 render_template 函数封装了该模板引擎
  • render_template 函数的第一个参数是模板的文件名,后面的参数都是键值对,表示模板中变量对应的真实值。

使用

  • { {}} 来表示变量名,这种 { {}} 语法叫做变量代码块
<h1>{
   { post.title }}</h1>

Jinja2 模版中的变量代码块可以是任意 Python 类型或者对象,只要它能够被 Python 的 str() 方法转换为一个字符串就可以,比如,可以通过下面的方式显示一个字典或者列表中的某个元素:

{
   {your_dict['key']}}
{
   {your_list[0]}}
  • 用 { %%} 定义的控制代码块,可以实现一些语言层次的功能,比如循环或者if语句
{% if user %}{
   { user }}
{% else %}hello!
<ul>{% for index in indexs %}<li> {
   { index }} </li>{% endfor %}
</ul>

注释

  • 使用 {# #} 进行注释,注释的内容不会在html中被渲染出来
{# {
   { name }} #}

 

 

模板的使用

如果你用pycharm , 并且创建项目时勾选flask ,那么项目根目录就会有一个templates文件夹。

 并且,默认的,template language 已经是 Jinjia2

 利用render_template( ) 进行渲染:

@app.route('/')
def index():return render_template('temp_demo.html')

 当然,可以传入字符串、列表、字典到模板中

@app.route('/')
def index():# return render_template('temp_demo.html')my_str = 'hello Scrat'my_int = 10my_array = [3,2,1,4,5,6]my_dict = {'name': 'scrat','age': 18}return render_template('temp_demo.html',my_str = my_str,my_int = my_int,my_array = my_array,my_dict = my_dict)

模板中代码:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
My module html template content:
<br/>{
   { my_str }}
<br/>{
   { my_int }}
<br/>{
   { my_array }}
<br/>{
   { my_dict }}</body>
</html>

运行结果:

当然,也可以进行相关运算:


<br/> my_int + 10 的和为:{
   { my_int + 10 }}
<br/> my_int + my_array第0个值的和为:{
   { my_int + my_array[0] }}
<br/> my_array 第0个值为:{
   { my_array[0] }}
<br/> my_array 第1个值为:{
   { my_array.1 }}
<br/> my_dict 中 name 的值为:{
   { my_dict['name'] }}
<br/> my_dict 中 age 的值为:{
   { my_dict.age }}
  • 结果
my_int + 10 的和为:20 
my_int + my_array第0个值的和为:13 
my_array 第0个值为:3 
my_array 第1个值为:4 
my_dict 中 name 的值为:scrat
my_dict 中 age 的值为:18

 

更多:Python 目录