Flask框架
所有Flask程序都必须创建一个程序实例,web服务器使用一种名为Web服务器网关接口(web Server Gateway Interface,WSGI)的协议,把接收的所有请求都转交给这个对象处理。
程序实例就是Flask类的对象,用如下代码创建:
from flask import Flask
app=Flask(__name__ )
程序实例需要知道滴哦每个URL请求运行了哪些代码,所以保存了一个URL到函数的映射关系。处理URL和函数之间关系的程序称为路由。
在Flask程序中定义路由的最简便的方式,是使用程序实例提供的app.route修饰器,把修饰器的函数注册为路由。程序实例用run方法启动Flask集成的Web服务器。
from flask import Flask
app=Flask(__name__)
@app.route('/')
def index():
return '<h1>Hello world!</h1>'
@app.route('/user/<name>')
def user(name):
return '<h1>hello,%s</h1>' % name
if __name__=='__main__':
app.run(debug=True)
请求响应循环
Flask从客户端收到请求时,要让视图函数能访问一些对象。request(请求对象)就是一个很好的例子,它封装了客户端发送的HTTP。
from hello import app
from flask import current_app
app_ctx=app.app_context()
app_ctx.push()
print(current_app.name)
app_ctx.pop()
Jinja2模板引擎
templates/index.html
<h1>hello world!</h1>
templates/users.html
<h1>Hello,{{name}}!</h1>
hello.py:渲染模板
from flask import Flask,render_template
@app.route('/')
def index():
return render_template('index.html')
@app.route('/user/<name>')
def user(name):
return render_template('user.html',name=name)
Flask提供的render_template函数把Jinja2模板引擎集成到了程序中。
render_template函数的第一个参数是模板的文件名,随后的参数都是键值对,表示模板中变量对应的真实的值。
{{name}}结构便是一个变量,告诉模板引擎这个位置的值从渲染模板时使用的数据中获取。例如:
<p>A value from a dicetionary:{{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}}
控制结构
在模板中使用条件控制语句:
{% if user %}
Hello,{{ user }}!
{% else %}
Hello,Stranger!
{% endif %}
在模板中使用for循环
<ul>
{% for comment in comments %}
<li>{{ comment }}</li>
{% endfor %}
</ul>
在模板中支持宏(类似于Python代码中的函数)
<% macro render_comment(comment) %}
<li>{{ comment }}</li>
<% endmacro %}
<ul>
{% for comment in comments %}
{{ render_comment(comment) }}
{% endfor %}
</ul>
为了重复使用宏,我们可以将其保存在单独的文件中,然后在需要使用的模板中导入:
{% import 'macros.html' as macros %}
<ul>
{% for comment in comments %}
{{ macros.render_comment(comment) }}
{% endfor %}
</ul>
模板继承(类似于Python中的类继承)
例如:首先创建一个名为base.html的基模板(block标签定义的元素可在衍生模板中修改)
<html>
<head>
{% block head %}
<title>{% block title %}{% endblock %} -My Application</title>
{% endblock %}
</head>
<body>
{% block body %}
{% endblcok %}
</body>
</html>
衍生模板:extends指令声明这个模板衍生自base.html
{% extends "base.html" %}
{% block title %}Index{% endblock %}
{% block head %}
{{ super() }}
<style>
</style>
{% endblock %}
{% block body %}
<h1>Hello,World!</h1>
{% endblock %}