在一个Flask
应用项目中,如果业务视图过多,可否将以某种方式划分出的业务单元单独维护,将每个单元用到的视图、静态文件、模板文件等独立分开?
例如从业务角度上,可将整个应用划分为用户模块单元、商品模块单元、订单模块单元,如何分别开发这些不同单元,并最终整合到一个项目应用中?
1.蓝图介绍
在Flask中,使用蓝图Blueprint
来分模块组织管理。蓝图实际可以理解为是一个存储一组视图方法的容器对象,其具有如下特点:
-
一个应用可以具有多个
Blueprint
-
可以将一个
Blueprint
注册到任何一个未使用URL
下比如“/user”、“/admin”
-
Blueprint
可以单独具有自己的模板、静态文件或者其它的通用操作方法,它并不是必须要实现应用的视图和函数的 -
在一个应用初始化时,就应该要注册需要使用的
Blueprint
但是一个Blueprint
并不是一个完整的应用,它不能独立于应用运行,而必须要注册到某一个应用中。
2.使用步骤
使用蓝图可以分为三个步骤
- 创建一个蓝图对象
# 创建一个蓝图
usersBlueprint = Blueprint('users', __name__)
- 在这个蓝图对象上进行操作,注册路由,指定静态文件夹,注册模版过滤器
# 在蓝图中定义一个视图函数
@usersBlueprint.route('/sanHa')
def sanHa():
return '<h1 style="color: blue">北极的三哈!</h1>'
- 在应用对象上注册这个蓝图对象
# 注册蓝图到应用程序中
app.register_blueprint(usersBlueprint, url_prefix='/users')
测试:运行app.py
文件
@app.route('/')
def san_ha(): # put application's code here
return '<h1 style="color: aqua">北极的三哈!</h1>'
访问:http://127.0.0.1:5000/users/sanHa
3.蓝图中的静态资源和模板
指定蓝图的url前缀
# 注册蓝图到应用程序中
app.register_blueprint(usersBlueprint, url_prefix='/users')
app.register_blueprint(order_bp, url_prefix='/order')
蓝图中的静态资源
和应用对象不同,蓝图对象创建时不会默认注册静态目录的路由。需要我们在 创建时指定 static_folder
参数。
下面的示例将蓝图所在目录下的static_admin
目录设置为静态目录
admin = Blueprint("admin", __name__, static_folder='static_admin')
app.register_blueprint(admin, url_prefix='/admin')
现在就可以使用 /admin/static_admin/<filename>
访问 static_admin
目录下的静态文件了。
也可通过 static_url_path
改变访问路径
admin = Blueprint("admin", __name__, static_folder='static_admin',static_url_path='/lib')
app.register_blueprint(admin, url_prefix='/admin')
蓝图中的模板
蓝图对象默认的模板目录为系统的模版目录,可以在创建蓝图对象时使用 template_folder
关键字参数设置模板目录
admin = Blueprint('admin', __name__, template_folder='my_templates')