Python Flask框架学习09:Flask 模板

32 篇文章 3 订阅

Flask 模板

 

可以以HTML的形式返回绑定到某个URL的函数的输出。例如,在以下脚本中,hello()函数将使用

标签呈现'Hello World'。

from flask import Flask
app = Flask(name)
@app.route('/')
def index():
   return '

'Hello World'
'

if name == 'main':
   app.run(debug = True)

但是,从Python代码生成HTML内容很麻烦,尤其是在需要放置变量数据和Python语言元素(如条件或循环)时。这需要经常从HTML中转义。

这是可以利用Flask所基于的Jinja2模板引擎的地方。而不是从函数返回硬编码HTML,可以通过render_template()函数呈现HTML文件。

from flask import Flask,render_template

app = Flask(__name__)

@app.route('/')
def index():
   return render_template(‘hello.html’)


if __name__ == '__main__':
   app.run(debug = True)

Flask将尝试在templates文件夹中找到HTML文件,该文件存在于此脚本所在的文件夹中。

  • Application folder
    • Hello.py
    • templates
      • hello.html

术语‘web templating system(web模板系统)’指的是设计一个HTML脚本,其中可以动态插入变量数据。web模板系统包括模板引擎,某种数据源和模板处理器。

Flask使用jinja2模板引擎。Web模板包含用于变量和表达式(在这些情况下为Python表达式)的HTML语法散布占位符,这些是在呈现模板时替换的值。

以下代码在templates文件夹中另存为hello.html 

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<body>
 <h1>Hello {{ zcy }}!</h1>
</body>
</html>

接下来,从Python shell运行以下脚本:

from flask import Flask, render_template

app = Flask(__name__)


@app.route('/hello/<user>')
def hello_name(user):
    return render_template('hello.html', zcy=user)


if __name__ == '__main__':
    app.run(debug=True)

当开发服务器开始运行时,打开浏览器并输入URL - http://localhost:5000/hello/mvl

URL的变量部分插入{{name}}占位符。

Web Templating System Example

Jinja2模板引擎使用以下分隔符从HTML转义。

  • {% ... %}用于语句
  • {{ ... }}用于表达式可以打印到模板输出
  • {# ... #}用于未包含在模板输出中的注释
  • # ... ##用于行语句

在下面的示例中,演示了在模板中使用条件语句。hello()函数的URL规则接受整数参数。它被传递到hello.html模板。其中,比较接收的数字(marks)的值(大于或小于50),因此有条件地呈现HTML。

Python脚本如下:

from flask import Flask, render_template

app = Flask(__name__)


@app.route('/hello/<int:score>')
def hello_name(score):
    return render_template('hello.html', marks=score)


if __name__ == '__main__':
    app.run(debug=True)

hello.html的HTML模板脚本如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
        "http://www.w3.org/TR/html4/loose.dtd">
<html>
<body>

{% if marks>50 %}
  <h1> Your result is pass!</h1>
  {% else %}
  <h1>Your result is fail</h1>
  {% endif %}

</body>
</html>

请注意,条件语句if-elseendif包含在分隔符{%..%}中。

运行Python脚本并访问URL http://localhost/hello/60,然后访问http://localhost/hello/30,以查看HTML的输出是否有条件地更改。

Python循环结构也可以在模板中使用。在以下脚本中,当在浏览器中打开URL http://localhost:5000/result时,result()函数会将字典对象发送到模板result.html

result.html的Template部分使用for循环将字典对象result{}的键和值对呈现为HTML表的单元格。

从Python shell运行以下代码:

from flask import Flask, render_template

app = Flask(__name__)


@app.route('/result')
def result():
    dict = {'phy': 50, 'che': 60, 'maths': 70}
    return render_template('result.html', result=dict)


if __name__ == '__main__':
    app.run(debug=True)

将以下HTML脚本保存为templates文件夹中的result.html

<!DOCTYPE html>
<html lang="en">

<body>

 <table border = 1>
     {% for key, value in result.items() %}

    <tr>
       <th> {{ key }} </th>
        <td> {{ value }} </td>
    </tr>

 {% endfor %}

  </table>

</body>
</html>

这里,对应于For循环的Python语句再次包含在{%..%}中,而表达式key和value放在{{}}中。

开发开始运行后,在浏览器中打开http://localhost:5000/result即可获得以下输出:

更多内容,可关注作者的微信公众号:胖哥真不错。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

胖哥真不错

您的鼓励,将是我最大的坚持!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值