什么是蓝图?
- 蓝图:用于实现单个应用的视图、模板、静态文件的集合。
- 蓝图就是模块化处理类
- 简单来说,蓝图就是一个存储操作路由映射方法的容器,主要用来实现客户端请求和URL相互关联的功能。
- 在Flask中,使用蓝图可以帮助我们实现模块化应用的功能。
蓝图运行机制:
蓝图是保存了一组将来可以在应用对象上执行的操作。注册路由就是一种操作,当程序实例上调用route
装饰器注册路由时,这个操作将修改url_map
路由映射列表。当我们在蓝图对象上调用route装饰器注册路由时,他只时在内部的一个延迟操作,记录列表defered_functions
中添加了一个项,当执行应用对象的register_blueprint()
方法时,应用对象从蓝图对象的defered_functions
列表中取出每一项,即调用应用对象的add_url_rule()
方法,这将会修改程序实例的路由映射列表。
蓝图的使用:
(1)创建蓝图
# Blueprint必须制定两个参数,admin表示蓝图名称,__name__表示蓝图所在模块
admin = Blueprint('admin', __name__)
(2)注册蓝图
# coding:utf-8
@admin.route('/')
def admin_index():
return 'admin_index'
(3)在程序实例中注册该蓝图
# url_prefix:相当于django中的namespace
app.register_blueprint(admin, url_prefix='/admin')
(4)示例
orders.py
# coding:utf-8
from flask import Blueprint
# 创建一个蓝图对象,蓝图就是一个小模块的抽象概念
app_orders = Blueprint("app_orders", __name__)
@app_orders.route('/get_orders')
def get_orders():
return 'get orders page'
main.py
# coding:utf-8
from flask immport Flask
from orders import app_orders
app = Flask(__name__)
app.register_blueprint(app_orders, url_prefix='/orders')
@app.route("/")
def index():
return 'index page'
if __name__ == "__main__":
app.run()
以目录形式定义蓝图:
(1)创建cart
包,将创建蓝图定义放在__init__
文件中
- cart/__init__.py
# coding:utf-8
from flask import Blueprint
# 创建一个蓝图对象,蓝图就是一个小模块的抽象概念
app_cart = Blueprint("app_cart", __name__)
# 在 __init__.py 文件被执行的时候,把视图加载进来,让蓝图与应用程序知道有视图的存在
from .views import get_cart
(2)创建views.py
文件,存放视图处理函数
- cart/views.py
# coding:utf-8
from . import app_cart
@app_cart.route('get_cart')
def get_cart():
return 'get cart page'
(3)创建templates模板文件目录
- cart/cart.html
<!DOCTYPE html>
<html>
<head>
<title></title>
</head>
<body>
<h1>cart page</h1>
</body>
</html>
(4)创建static静态文件目录
(5)将蓝图注册到程序中
- main.py
# coding:utf-8
from flask immport Flask
from orders import app_orders
from cart import app_cart
app = Flask(__name__)
app.register_blueprint(app_orders, url_prefix='/orders')
app.register_blueprint(app_cart, url_prefix='/cart')
@app.route("/")
def index():
return 'index page'
if __name__ == "__main__":
app.run()
蓝图里模板目录的处理:
(1)错误示例:直接这样使用是会报错的。
- cart/views.py
# coding:utf-8
from . import app_cart
from flask import render_template
@app_cart.route('get_cart')
def get_cart():
return render_template('cart.html')
(2)正确示例:我们需要在创建蓝图时指定使用的模板目录
- cart/__init__.py
# coding:utf-8
from flask import Blueprint
# 创建一个蓝图对象,蓝图就是一个小模块的抽象概念
app_cart = Blueprint("app_cart", __name__, template_folder='templates')
# 在 __init__.py 文件被执行的时候,把视图加载进来,让蓝图与应用程序知道有视图的存在
from .views import get_cart
(3)此时使用就不会报错了
- cart/views.py
# coding:utf-8
from . import app_cart
from flask import render_template
@app_cart.route('get_cart')
def get_cart():
return render_template('cart.html')