Flask初识,第九篇,Flask中的蓝图

Posted duanhaoxin

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Flask初识,第九篇,Flask中的蓝图相关的知识,希望对你有一定的参考价值。

 

蓝图,听起来就是一个很宏伟的东西

在Flask中的蓝图 blueprint 也是非常宏伟的

它的作用就是将 功能 与 主服务 分开怎么理解呢?

比如说,你有一个客户管理系统,最开始的时候,只有一个查看客户列表的功能,后来你又加入了一个添加客户的功能(add_user)模块, 然后又加入了一个删除客户的功能(del_user)模块,然后又加入了一个修改客户的功能(up_user)模块,在这个系统中,就可以将

查看客户,修改客户,添加客户,删除客户的四个功能做成蓝图加入到客户管理系统中,本篇最后会做一个这样的例子,但是首先我们要搞清楚什么是蓝图 blueprint

 

1.初识Flask蓝图(blueprint)

创建一个项目然后将目录结构做成:

技术分享图片

s_view.py 文件中的内容

技术分享图片
from flask import Blueprint  # 导入 Flask 中的蓝图 Blueprint 模块

sv = Blueprint("sv", __name__)  # 实例化一个蓝图(Blueprint)对象


@sv.route("/svlist")  # 这里添加路由和视图函数的时候与在Flask对象中添加是一样的
def view_list():
    return "svlist_view_list"
技术分享图片

manager.py 文件中的内容

技术分享图片
from flask import Flask

# 导入此前写好的蓝图模块
from student_view import s_view

app = Flask(__name__)  # type:Flask

# 在Flask对象中注册蓝图模块中的蓝图对象 s_view 中的 sv
app.register_blueprint(s_view.sv)

app.run("0.0.0.0",5000)
# 现在Flask对象中并没有写任何的路由和视图函数
技术分享图片

开启服务,然后访问 http://127.0.0.1:5000/svlist 查看结果

技术分享图片

很明显,我们没有在Flask对象中添加路由,但是我们注册了有路由和视图函数的sv蓝图对象

 

2.如何理解蓝图呢?

其实我们可以理解成一个没有run方法的Flask对象,这个理论虽然有很多的漏洞,但是对于刚接触蓝图的你来说,就这么样理解,没有错

下面来看一下,在实例化蓝图的时候可以传递的参数都有什么,你就能完全理解了

技术分享图片

这是目录结构

s_view.py 文件中的内容 :

技术分享图片
from flask import Blueprint  # 导入 Flask 中的蓝图 Blueprint 模块
from flask import render_template

sv = Blueprint("sv",
               __name__,
               template_folder="sv_template",  # 每个蓝图都可以为自己独立出一套template模板文件夹,如果不写则共享项目目录中的templates
               static_folder="sv_static"  # 静态文件目录也是可以独立出来的
               )  # 实例化一个蓝图(Blueprint)对象


@sv.route("/svlist")
def view_list():
    return render_template("svlist.html")
技术分享图片

svlist.html 文件中的内容

技术分享图片
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    Hello ! I am sv_template
    <img src="/sv_static/DragonFire.png">
</body>
</html>
技术分享图片

从这个例子中我们总结出:

Blueprint 其实可以理解为一个了没有run方法的 Flask 对象

只要Blueprint被 Flask 注册了,就一定会生效

坑来了!坑来了!

蓝图内部的视图函数及route不要出现重复,否则~你们自己试试吧

 

3.使用蓝图,做一个增删改查用户

要有一个文件存放我们的原始数据

student_data.py 文件中的内容:

STUDENT = [
    {‘id‘: 1, ‘name‘: ‘Old‘, ‘age‘: 38, ‘gender‘: ‘中‘},
    {‘id‘: 2, ‘name‘: ‘Boy‘, ‘age‘: 73, ‘gender‘: ‘男‘},
    {‘id‘: 3, ‘name‘: ‘EDU‘, ‘age‘: 84, ‘gender‘: ‘女‘}
]

然后我们根据以上内容进行增删改查

 

3.1 使用蓝图进行web应用搭建:

技术分享图片

__init__.py 文件中的内容:

技术分享图片
from flask import Flask


def create_app():
    app = Flask(__name__)

    return app
技术分享图片

这个文件我们会修改函数 create_app中的代码

manager.py 文件中的内容

from student import create_app

flask_app = create_app()

flask_app.run("0.0.0.0",5000)

通过这种方式启动 Flask 程序

 

3.2 使用Flask蓝图,查看学生信息

技术分享图片

s_list.html 文件中的内容:

技术分享图片 s_list.html

stu_select.py 文件中的内容:

技术分享图片 stu_select.py

student/__init__.py 文件中的内容:

技术分享图片 student/__init__.py

赶紧运行一下manager.py 来访问一下,我们的成果

技术分享图片

什么链接都不要点,因为点啥都不好使,之后咱们一个一个的做

 

3.3. 使用Flask蓝图,添加一个学生

技术分享图片

s_add.html 文件中的内容

技术分享图片 s_add.html

stu_add.py 文件中的内容

技术分享图片 stu_add.py

这里面我们让他添加完一个学生,就返回到s_list查看学生列表

student/__init__.py 文件中的内容

技术分享图片 student/__init__.py

如果你要是重新启动服务了,那么你刚刚添加的学生信息就没有了

技术分享图片

添加完成之后

技术分享图片

添加学生的Blueprint已经做完了

 

3.4. 使用Flask蓝图,修改学生信息

技术分享图片

s_update.html 文件中的内容:

技术分享图片 s_update.html

stu_update.py 文件中的内容:

技术分享图片 stu_update.py

student/__init__.py 文件中的内容:

技术分享图片 student/__init__.py

试一下结果:

技术分享图片

技术分享图片

删除学生信息

技术分享图片
1 @app01.route("/delete/<int:nid>",methods=["GET","POST","DELETE"])
2 def delete(nid):
3     print(nid)
4     STUDENT.pop(nid-1)
5     return redirect("/index")
删除代码

 

 

第九篇,完结

以上是关于Flask初识,第九篇,Flask中的蓝图的主要内容,如果未能解决你的问题,请参考以下文章

Flask 第九篇flask-script组件

第九篇 Flask的before_request和after_request

flask第九篇——url_for

flask第九篇——url_for

Flask中的蓝图(BluePrint)

Flask--蓝图