标签:基于 使用 var flask 类型 title 生成 继承 method
接着上文
讲一讲响应
flask调用视图函数后,会将其返回值作为响应的内容。大多数情况下,响应就是一个简单的字符串,作为HTML页面回送客户端。但HTTP协议需要的不仅是作为请求响应的字符串。HTTP响应中一个重要的部分是状态码,flask默认设为200,这个代码表明请求被成功处理。如果视图函数返回的响应需要使用不同的状态码,那么可以把数字代码作为第二个返回值,添加到响应文本之后。如下代码
@app.route(‘/wrong‘) def wrong(): return ‘<h1>Bad Rquest</h1>‘,400
启动服务后,在浏览器输入url还是能得到返回值的,
但是在cmd里可以看到
如果是正常的返回就是下面那个200,当然除了400外你可以设置成别的,还是会显示出来的
有一种名为重定向的特殊响应类型,这种响应没有页面文档,只告诉浏览器一个新地址用以加载新页面,常用于表单中。常使用302状态码表示,指向的地址有location首部提供。重定向响应可以使用3个值形式的返回值生成,也可以在Response对象中设定。不过由于使用频繁,Flask提供了,redirect()的辅助函数,用于生成这种响应
from flask import redirect @app.route(‘/‘) def index(): return redirect(‘http://www.example.com‘)
之后访问127.0.0.0:5000,他就会指向http://www.example.com/这个页面
上图来自《Flask Web开发:基于Python的Web应用开发实战(第2版)》
之前我们用到的<h1>Hello World!</h1>就是一张jinja2模板,不过相对于return ‘<h1>Hello,%s !</h1>‘ %name这样返回name,jinja是这样的<h1>Hello, {{ name }}!</h1>
之前那样的话有点不符合web开发,按道理应该是返回到文本的,我们可以先创建一个templates文件夹,在里面放入index.html和user.html。把上面两句话打进去,然后我们去修改hello.py
from flask import Flask,render_template @app.route(‘/‘) def index(): return render_template(‘index.html‘) @app.route(‘/user/<name1>‘) def user(name1): return render_template(‘user.html‘,name = name1)
保存,然后去访问,会发现得到的效果是一样的。
在user.html文件里有一个{{ name }},表示一种特殊的占位符,jinja2能识别所有类型的变量,甚至是一些复杂的类型,例如列表,字典和对象,如下
<p>A value from a dictionary: {{ mydict[‘key‘] }}.</p> <p>A value from a list: {{ mylist[3] }}.</p> <p>A value from a list, with a variable index: {{ mylist[myintvar] }}.</p> <p>A value from an object‘s method: {{ myobj.somemethod() }}.</p>
也可以用过滤器修改变量,过滤器名加载变量名之后,如Hello, {{ name|capitalize }},就是加了一个过滤器。
jinja变量过滤器有以下几个
完整的过滤器列表在这https://jinja.palletsprojects.com/en/2.10.x/templates/#builtin-filters
jinja提供了多种控制结构,举几个简单的例子,
条件控制
<ul> {% for comment in comments %} <li>{{ comment }}</li> {% endfor %} </ul>
for循环
<ul> {% for comment in comments %} <li>{{ comment }}</li> {% endfor %} </ul>
还可以把需要重复使用的代码写入单独的文件,然后包含在模板用
{% include ‘common.html‘ %}
当然还可以继承,
<html> <head> {% block head %} <title>{% block title %}{% endblock %} - My Application</title> {% endblock %} </head> <body> {% block body %} {% endblock %} </body> </html>
{% extends "base.html" %} {% block title %}Index{% endblock %} {% block head %} {{ super() }} <style> </style> {% endblock %} {% block body %} <h1>Hello, World!</h1> {% endblock %}
第一段代码就是基代码,第二段是继承之后的代码
说起来django用的应该也是jinja,我一直以为是django特色。。。。
然后用上面那些知识就可以自定义错误页面
@app.errorhandler(404) def page_not_found(e): return render_template(‘404.html‘), 404 @app.errorhandler(500) def internal_server_error(e): return render_template(‘500.html‘), 500
这样报错的话就会返回你指定的页面了
在定义动态路由链接的时候我们可以用url_for辅助函数。
他可以直接调用视图里的url,并在上面加上参数。如url_for(‘index‘)得到的结果应该是127.0.0.1:5000/如果加上点参数就是这样的url_for(‘index‘, page=3),返回结果是/?page=2。
当然还可以这样用(‘user‘, name=‘Red‘, _external=True),那么返回结果就是127.0.0.1:5000/user/Red这样的了。
标签:基于 使用 var flask 类型 title 生成 继承 method
原文地址:https://www.cnblogs.com/afei123/p/11291648.html