Flask(六)——模板

Flask可以以HTML形式返回绑定到某个URL的函数的输出。


在以下脚本中,hello() 函数将使用附加的 <h1> 标记呈现 'Hello World'

from flask import Flask

app = Flask(__name__)


@app.route('/')
def index():
    return "<html><body><h1>'Hello World'</h1></body></html>"


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

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

它可以利用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文件。

术语“Web模板系统”是指设计一个HTML脚本,其中可以动态插入变量数据。 Web模板系统由模板引擎,某种数据源和模板处理器组成。

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

以下代码在模板(templates)文件夹中保存为: hello.html

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Flask HTTP请求方法处理</title>
</head>
   <body>
      <h1>Hello {{ name }}!</h1>
   </body>
</html>

接下来,将以下代码保存在 app.py 文件中,并运行。

from flask import Flask, render_template

app = Flask(__name__)


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


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

在开发服务器开始运行时,打开浏览器并输入URL为 http://localhost:5000/hello/maxsu。可以发现URL的可变部分插入{{name}}占位符处。

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

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

在以下示例中,演示了在模板中使用条件语句。 hello() 函数的URL规则接受整数参数。 它传递给 hello.html 模板。 在它里面,收到的数字(标记)的值被比较(大于或小于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模板脚本如下

<html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>Flask模板示例</title>
 </head>
    <body>
       {% if marks>=60 %}
       <h1> 通过考试!</h1>
       {% else %}
       <h1>未通过考试!</h1>
       {% endif %}
    </body>
 </html>

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

运行Python脚本并访问URL=> http://localhost:5000/hello/60 ,然后访问 http://localhost:5000/hello/59,以有条件地查看HTML输出。

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

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

Python脚本如下

from flask import Flask, render_template

app = Flask(__name__)


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


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

将以下HTML脚本保存为模板文件夹(templates)中的模板文件: result.html

<html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>Flask模板示例</title>
 </head>
    <body>
       <table border = 1>
          {% for key, value in result.items() %}
             <tr>
                <th> {{ key }} </th>
                <td> {{ value }} </td>
             </tr>
          {% endfor %}
       </table>
    </body>
 </html>

在这里,与 For 循环相对应的Python语句包含在 {%...%} 中,而表达式键和值放在 {{}} 中。

开发开始运行后,在浏览器中打开http://localhost:5000/result。可以看到输出键值对的列表。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值