为什么要使用蓝图?
我的理解就是把不同功能进行模块化,通过模块的划分可以更好的组织项目的目录结构,使项目的整个框架更加清
晰
假如在一个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的转发有异曲同工之妙。
版权声明:本文为qq_45425667原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。