先讲个有趣的小问题,我也是道听途说,但是确实很有意义。
我们做的项目都有上线的时候,也有在原项目中添加功能模块的时候,那么奇葩的人会在原文件中不断添加功能模块,终于有一天,文件达到了好几兆,最后运行编辑器的时候,编辑器都崩了,这就是内存超标,这种文题其实可以很好避免。下边会提到蓝图(blueprint)。
也就是说,随着业务代码的增加,将所有代码都放在单个程序文件中,是非常不合适的。这不仅会让代码阅读变得困难,而且会给后期维护带来麻烦。
什么是蓝图
蓝图:用于实现单个应用的视图、模板、静态文件的集合。
蓝图就是模块化处理的类。
简单来说,蓝图就是一个存储操作路由映射方法的容器,主要用来实现客户端请求和URL相互关联的功能。 在Flask中,使用蓝图可以帮助我们实现模块化应用的功能。
蓝图的运行机制
蓝图是保存了一组将来可以在应用对象上执行的操作。注册路由就是一种操作,当在程序实例上调用route装饰器注册路由时,这个操作将修改对象的url_map路由映射列表。当我们在蓝图对象上调用route装饰器注册路由时,它只是在内部的一个延迟操作记录列表defered_functions中添加了一个项。当执行应用对象的 register_blueprint() 方法时,应用对象从蓝图对象的 defered_functions 列表中取出每一项,即调用应用对象的 add_url_rule() 方法,这将会修改程序实例的路由映射列表。
蓝图的使用
# -*- encoding: utf-8 -*-
# 使用蓝图需要依赖Blueprint库
from flask import Flask,Blueprint
# 导入自定义的蓝图文件
from day06_part import myPart
# 建立对象
app = Flask(__name__)
# 载入配置文件
app.config.from_pyfile('config.ini')
# 注册定义好的蓝图文件
# 如果有url_prefix就需要在进入路由时传俩个参数。因为在mypart中已经传入一个参数了
# 给蓝图的url加前缀。/part
# 如果前缀名称一致,会覆盖主模块
# app.register_blueprint(myPart,url_prefix='/part')
# app.register_blueprint(myPart)
app.register_blueprint(myPart,url_prefix='/part')
# 配置路由
@app.route('/')
def index():
return '这里是主模块首页'
# 程序入口
if __name__ == "__main__":
app.run()
再来看附模块
在新建一个py
# -*- encoding: utf-8 -*-
from flask import Flask, Blueprint
app = Flask(__name__)
app.config.from_pyfile('config.ini')
# 注册蓝图
myPart = Blueprint('myPart',__name__)
@myPart.route('/part')
def my_part():
return '这里是部分功能'
@myPart.route('/test')
def my_test():
return '这里是部分功能test'
其中两个文件相辅相成, 不喜轻喷。