flask框架--模板

  今天又是一个精彩有无聊的一天,不过随着知识的缓慢的增加我的内心也充满了干劲,虽然前进的有些缓慢 但我不会这么容易放弃的,一定要相信自己,不要灰心

好了 ~ 不说废话了 , 我自己听的都有些受不了了 。

  我呢  , 今天学习了模板,在这里我给大家说说几句 关于模板的

  首先说一下模板的作用:模板可以承担视图函数又可以返回响应的内容

  视图函数只负责业务逻辑和数据处理(业务逻辑方面),而模板则取到视图函数的数据结果进行展示(视图展示方面)

代码结构清晰,耦合度底。

  模板引擎有很多,不过在这里我给大家说的是Jinjia2 ,它是在Python下一个被广泛应用的模板引擎,是有Python实现的模板语言,他的设计思想来源于Django的模板引擎,并扩展了其语法金和一系列强大的功能,其实Flask内置的模板语言。

  模板语言:是一种被设计来自动生成文档的简单文本格式,在模板语言中,一般都会把一些变量传给模板,途欢模板的特定文职上预先定义好的占位变量名。

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

  {{}} 来表示变量名,这种语法叫做变量代码块,在变量代码块中可以是任意Python类型或者对象,只要能够被转换成str()类型就可以,{%%} 用这个来定义的控制块代码,可以实现一些语言层次的功能,比如循环语句或者if语句,{##} 使用这个符号进行注释,注释的内容不会再html中被渲染出来。

  接下来我给大家展示一个实例:

扫描二维码关注公众号,回复: 4594932 查看本文章

  第一步 当然先导入模块啦

  from flask import,render_template

  建立对象

  app = Flask(__name__)

  导入配置文件  #我喜欢这个方法,当然也可以用其他的方法

  app.config.from_pyfile('config.ini')

 路由

  @app.route('/')

  def index():

    context = {}

    context['my_str'] = ‘你好世界’

    context['my_int'] = 100

    context['my_list'] = [4,3,2,4,2,3]

    context['my_dict'] = {'name':'xiaoming','age':19}

    使用render_template模块来渲染模板文件,通过第二个参数传递数据变量,通过**引用来将嵌套dict直接传递给模板

    return render_template('day3.html',**context)

 if __name__ == "__main__":

    app.run()

这是一个模板文件,还得写一个day3.html的文件的网页模板

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>flask网页模板的学习</title>
</head>
<body>
 
 
<div>
这是我们的网页模板
<br /><br />
{# 这里是注释,最基本的模板语法,输出一个变量 #}
{{ my_str }}
<br /><br />
{# 模板语法可以做简单的运算操作#}
{{my_int+44}}
<br /><br />
{# 模板语法可以以下标引用的方式输出list元素#}
{{my_list [0] }} {{my_list.1 }}
<br /><br />
{{my_dict['name']}} {{my_dict.age}}
<br /><br />
{# 使用{%%}来定义简单的逻辑控制代码#}
{% if my_int %}
整形存在
{% else%}
不存在
{# 使用if判断,一定要有endif 用来结束逻辑判断#}
{% endif%}

<ul>
{# 使用for循环来遍历list , for 也必须endfor 用来结束循环 #}
{% for item in my_list %}
<li>{{item}}</li>
{% endfor %}
</ul>


{# 使用 if for 嵌套来实现单双行背景色 #}
<table style="border:1px solid black; padding:5px;">
{% for item in my_list %}
{# 使用loop关键字可以调用循环的索引,用来判断下标单双数 #}
{% if loop.index % 2 == 0 %}
<tr style="<td>{{ item }}</td></tr>
{% else %}
<tr style="<td>{{ item }}</td></tr>
{% endif %}

{% endfor %}
</table>
</div>
</body>
</html>

接下来说一下过滤器:

过滤器的本质就是函数。有时候我们不仅仅只是需要输出变量的值,我们还需要修改变量的显示,甚至格式化,运算等等,而在模板中是不能直接调用Python中的某些方法,那么过滤器的作用就找到了。

使用方法:变量名|过滤器  {{variable | filter_name(*args)}},如果没有任何参数传给过滤器,则可以吧吧括号省略掉 

猜你喜欢

转载自www.cnblogs.com/weifeng-888/p/10157404.html
今日推荐