我的理解就是把不同功能进行模块化,通过模块的划分可以更好的组织项目的目录结构,使项目的整个框架更加清
晰
假如在一个app.py文件里面有有以删除,添加,登录…功能这样使文件看起来很乱,不利于维护,我这么说并不是代表就不能在app这个文件里面写这么多的代码,只是写的太多不好维护。
1.使用蓝图按照以下的顺序:
创建蓝图–>在flask的APP中引入蓝图–>注册蓝图
我们将创建一个main_func1、other、user的蓝图,并在flask_init文件中注册这些蓝图。
文件结构如下:
2. 创建蓝图
创建蓝图就是创建一个文件,然后给他注册好名字,随后引入。
main_func.py文件
# 引入Blueprint包
from flask import Blueprint
# 创建蓝图,名字叫做main_fun
main_fun1 = Blueprint("main_fun", __name__)
# 创建该蓝图下的路由
@main_fun1.route("/home")
def x1():
data = {
"main_fun": "java",
}
return data
other.py文件
from flask import Blueprint
other = Blueprint("other", __name__)
@other.route("/home")
def x1():
data = {
"other": "other",
}
return data
user.py文件
from flask import Blueprint
user = Blueprint("user", __name__)
@user.route("/home")
def x1():
data = {
"user": "user",
}
return data
3. 创建app与注册蓝图
在flask_init.py文件中创建APP,并注册蓝图
from flask import Flask # 引入蓝图 from .main_func import main_fun1 from .other import other from .user import user # 创建flask对象 app = Flask(__name__) # 注册蓝图 # url_prefix是设置访问这个蓝图的时候需要带上的路由 app.register_blueprint(main_fun1, url_prefix='/main_fun') app.register_blueprint(user, url_prefix='/user') app.register_blueprint(other, url_prefix='/other')
4.测试
url_prefix的作用
5.蓝图的作用
在每个蓝图下面设置相同的home路由
main_func.py下的路由:
other.py下的路由:
user.py下的路由:
注意:note:在引入的时候会出现下面的错误,查看原因是由于它不能识别这个文件是个模块,因此需要在当前文件下面建一个__init__.py的文件
importError: attempted relative import with no known parent package
5.总结
通过我们的例子可以看到蓝图作为一个分发管理的工具,在flask开发的过程中尤为重要,与Django开发的时候设置url的转发有异曲同工之妙。



