在python Flask中,我们有时需要将一个网站良好的组织起来,形成开发人员易于理解的结构。app.py一个文件不足以完成这样的任务,需要承载所有的链接,还要做出单独的错误处理、日志处理等功能,都放在一个文件中就比较臃肿。Flask提供了蓝图这种想法,来做这件事。所谓蓝图,实际是将多个路径(/***)下面的函数放到多个文件。通过Flask蓝图的注册机制,让app.py知道某一个链接的路由应该找哪一个子文件。这样的子文件,可以认为是路由注册文件。

Blueprint源代码中大体的想法,是先提供一组Blueprint的函数,通过注册机制让主文件,类似app.py这样的文件知道注册了一些路径。再让主文件在收到请求时,去包含该路径的子文件查找页面逻辑,最后render在view中。

操作:定义子文件,比如B.py,在内部定义函数,用flask的Blueprint初始化childroute,然后用@childroute.route(),def函数去做闭包。

在主文件中,对执行体app进行蓝图注册,用register_blueprint函数。

app.py示例:

增加注册

from flask import Flask
from simple_page.simple_page import simple_page

#goto localhost:5000/hello
app = Flask(__name__)
app.register_blueprint(simple_page)

# Blueprint can be registered many times
#goto localhost:5000/pages/hello
app.register_blueprint(simple_page, url_prefix='/pages')
app.register_blueprint(simple_page, url_prefix='/dir')


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

从上面的多个register_blueprint函数可以看到,一个文件可以被注册多次,这样不同的路径就可以指向同一个目标文件、同一个函数了。import时,就从simple_page文件夹中的simple_page文件导入一个simple_page包

蓝图的子文件示例:

from flask import Blueprint, render_template, abort
from jinja2 import TemplateNotFound

simple_page = Blueprint('simple_page', __name__,
                        template_folder='templates')

@simple_page.route('/', defaults={'page': 'index'})
@simple_page.route('/<page>')
def show(page):
    try:
        return render_template('pages/%s.html' % page)
    except TemplateNotFound:
        abort(404)

将它们分别放入以下的文件夹:

example

|--app.py

|--simple_page

  |--simple_page.py

|--templates

  |--pages

    |--hello.html

    |--index.html

    |--layout.html

    |--world.html

对应关系如下;

app.register_blueprint(new_page)    对应  

new_page = Blueprint('new_page', __name__,

                        template_folder='templates')

这个函数的第一个参数可以和外面的new_page不同名。

Logo

瓜分20万奖金 获得内推名额 丰厚实物奖励 易参与易上手

更多推荐