作者:f蓝色基因__987 | 来源:互联网 | 2024-10-25 14:21
Blueprint概念
简单来说,Blueprint 是一个存储操作方法的容器,这些操作在这个Blueprint 被注册到一个应用之后就可以被调用,Flask 可以通过Blueprint来组织URL以及处理请求。
Flask使用Blueprint让应用实现模块化,在Flask中,Blueprint具有如下属性:
- 一个应用可以具有多个Blueprint
- 可以将一个Blueprint注册到任何一个未使用的URL下比如 “/”、“/sample”或者子域名
- 在一个应用中,一个模块可以注册多次
- Blueprint可以单独具有自己的模板、静态文件或者其它的通用操作方法,它并不是必须要实现应用的视图和函数的
- 在一个应用初始化时,就应该要注册需要使用的Blueprint
但是一个Blueprint并不是一个完整的应用,它不能独立于应用运行,而必须要注册到某一个应用中。
初识蓝图
蓝图/Blueprint对象用起来和一个应用/Flask对象差不多,最大的区别在于一个 蓝图对象没有办法独立运行,必须将它注册到一个应用对象上才能生效
使用蓝图可以分为三个步骤
admin=Blueprint('admin',__name__)
@admin.route('/')
def admin_home():return 'admin_home'
app.register_blueprint(admin,url\_prefix='/admin')
当这个应用启动后,通过/admin/可以访问到蓝图中定义的视图函数
蓝图使用案例
主函数
from flask import Flask
from datail import datail_b
from news import admin_b
app = Flask(__name__)app.register_blueprint(datail_b)
app.register_blueprint(admin_b)
"""
一. 为什么创建蓝图:
1.对flask应用程序进行模块化管理
2.提升开发效率,降低开发难度,协同开发3.解决了循环导入问题4.创建蓝图的步骤
from flask import Blueprint 导入蓝图定义路由
@app_bu.rout
def xxxx():xxx在主页面用app将其他文件中的蓝图注册,
使代码实现模块化管理"""
if __name__ == "__main__":print(app.url_map) app.run()
单文件蓝图
from flask import Blueprintdatail_b = Blueprint("datail",__name__)"""
一个蓝图在本文件中可以定义若干个视图函数"""
@datail_b.route('/datail')
def datail():return "datails"
模块化蓝图使用
init文件
from flask import Blueprintadmin_b = Blueprint("admin",__name__,url_prefix="/admin")
from .views import *
views文件
from news import admin_b
"""
将所有的视图函数定义在views文件中,
虽然从news导入了蓝图,但是仅仅是views文件建立了对于__init__函数的依赖
但是__init__函数对于此文件还是没有任何的关联,
所以仅仅是做到这一步在运行的时候url_map还是不能将此路由打印出来
还要再将此文件中的所以的视图函数再反导入__init__函数中,才会有应有的效果"""
@admin_b.route("/")
def admin():return "admin"@admin_b.route('/index')
def admin_index():return "admin_index"
运行机制
- 蓝图是保存了一组将来可以在应用对象上执行的操作,注册路由就是一种操作
- 当在应用对象上调用 route 装饰器注册路由时,这个操作将修改对象的url_map路由表
- 然而,蓝图对象根本没有路由表,当我们在蓝图对象上调用route装饰器注册路由时,它只是在内部的一个延迟操作记录列表defered_functions中添加了一个项
- 当执行应用对象的 register_blueprint() 方法时,应用对象将从蓝图对象的 defered_functions 列表中取出每一项,并以自身作为参数执行该匿名函数,即调用应用对象的 add_url_rule() 方法,这将真正的修改应用对象的路由表
蓝图的url前缀
- 当我们在应用对象上注册一个蓝图时,可以指定一个url_prefix关键字参数(这个参数默认是/)
- 在应用最终的路由表 url_map中,在蓝图上注册的路由URL自动被加上了这个前缀,这个可以保证在多个蓝图中使用相同的URL规则而不会最终引起冲突,只要在注册蓝图时将不同的蓝图挂接到不同的自路径即可
- url_for
url_for('admin.index')