当前位置:   article > 正文

Flask - Flask的蓝图(BluePrint)

菜鸟教程 flask蓝图

目录

  • Flask - Flask的蓝图(BluePrint)
    • 一. 初始Flask蓝图
    • 进阶Flask蓝图
      • 使用蓝图做一个增删改查
      • 1.使用蓝图进行web应用搭建:
      • 2.使用Flask蓝图,查看学生信息
      • 3. 使用Flask蓝图,添加一个学生
      • 4. 使用Flask蓝图,修改学生信息
      • 5. 蓝图目录

Flask - Flask的蓝图(BluePrint)

百度说蓝图这个词有两个意思:

1.通常用铁氰化和铁盐敏化的纸或布,曝光后用清水冲洗显影晒成的蓝底白图的相纸,特别供晒印地图、机械图、建筑图样用。

2.一个详细的、各部分完全协调的计划或行动规划。

但是跟Flask的蓝图没有一毛关系~

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

比如说,你有一个客户管理系统,最开始的时候,只有一个查看客户列表的功能,后来你又加入了一个添加客户的功能(add_user)模块,
然后又加入了一个删除客户的功能(del_user)模块,然后又加入了一个修改客户的功能(up_user)模块,在这个系统中,就可以将 查看客户,修改客户,添加客户,删除客户的四个功能做成蓝图加入到客户管理系统中,本篇最后会做一个这样的例子,但是首先我们要搞清楚什么是蓝图 blueprint

一. 初始Flask蓝图

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

 

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蓝图对象

进阶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>

访问 127.0.0.1:5000/svlist 即可显示页面.

注意:蓝图内部的视图函数及route不要出现重复

    使用蓝图做一个增删改查

    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 程序

 

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

s_list.html 文件中的内容:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>学生列表</title>
</head>
<body>
<table border="3xp">
    <thead>
    <tr>
        <td>ID</td>
        <td>name</td>
        <td>age</td>
        <td>gender</td>
        <td>options</td>
    </tr>
    </thead>
    <tbody>
    {% for foo in student %}
        <tr>
            <td>{{ foo.id }}</td>
            <td>{{ foo["name"] }}</td>
            <td>{{ foo.get("age") }}</td>
            <td>{{ foo.gender }}</td>
            <td> <a href="/s_update/{{ foo.id }}">修改</a> | <a href="/s_del?id={{ foo.id }}">删除</a> </td>
        </tr>
    {% endfor %}
    </tbody>
</table>
<a href="/s_add"> 添加学生 </a>
</body>
</html>

stu_select.py 文件中的内容:

from flask import Blueprint
from flask import render_template
from student_data import STUDENT

ss_blueprint = Blueprint("ss_b", __name__, template_folder="html", static_folder="static")


@ss_blueprint.route("/s_list")
def s_list():
    return render_template("s_list.html", student=STUDENT)

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

from flask import Flask
from student_select import stu_select


def create_app():
    app = Flask(__name__)  # type:Flask

    app.register_blueprint(stu_select.ss_blueprint)

    return app

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

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

s_add.html 文件中的内容

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>学生列表</title>
</head>
<body>
<form method="post">
    ID:<input type="text" name="id"> <br>
    姓名:<input type="text" name="name"><br>
    年龄:<input type="text" name="age"><br>
    性别:<input type="text" name="gender"><br>
    <input type="submit" value="添加学生">
</form>

</body>
</html>

stu_add.py 文件中的内容

from flask import Blueprint
from flask import redirect
from flask import request
from flask import render_template
from student_data import STUDENT

s_add = Blueprint("s_add", __name__, template_folder="html", static_folder="static") # type:Blueprint


@s_add.route("/s_add",methods=["GET","POST"])
def s_add_view():
    if request.method == "POST":
        stu_dic = {
            "id": request.form["id"],
            "name": request.form["name"],
            "age": request.form["age"],
            "gender": request.form["gender"]
        }

        STUDENT.append(stu_dic)

        return redirect("/s_list")

    return render_template("s_add.html")

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

student/init.py 文件中的内容

from flask import Flask
from student_select import stu_select
from student_add import stu_add


def create_app():
    app = Flask(__name__)  # type:Flask

    app.register_blueprint(stu_select.ss_blueprint)
    app.register_blueprint(stu_add.s_add)

    return app

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

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

s_update.html 文件中的内容:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>学生列表</title>
</head>
<body>
<form method="post">
    <input type="text" name="id" hidden value="{{ student.id }}"><br>
    姓名:<input type="text" name="name" value="{{ student.name }}"><br>
    年龄:<input type="text" name="age" value="{{ student.age }}"><br>
    性别:<input type="text" name="gender" value="{{ student.gender }}"><br>
    <input type="submit" value="修改信息">
</form>

</body>
</html>

stu_update.py 文件中的内容:

from flask import Blueprint
from flask import render_template
from flask import redirect
from flask import request
from student_data import STUDENT

s_update = Blueprint("s_update", __name__, template_folder="html", static_folder="static")


@s_update.route("/s_update/<int:nid>",methods=["GET","POST"])
def s_update_view(nid):
    if request.method == "POST":
        stu_id = int(request.form["id"])
        stu_dic = {
            "id": stu_id,
            "name": request.form["name"],
            "age": request.form["age"],
            "gender": request.form["gender"]
        }

        for index,stu in enumerate(STUDENT):
            if stu["id"] == stu_id:
                STUDENT[index] = stu_dic

        return redirect("/s_list")

    for stu in STUDENT:
        if stu["id"] == nid :
            return render_template("s_update.html", student=stu)

    return render_template("s_update.html", student="")

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

from flask import Flask
from student_select import stu_select
from student_add import stu_add
from student_update import stu_update


def create_app():
    app = Flask(__name__)  # type:Flask

    app.register_blueprint(stu_select.ss_blueprint)
    app.register_blueprint(stu_add.s_add)
    app.register_blueprint(stu_update.s_update)

    return app

试一下结果:

删除自己做吧..

  5.蓝图目录

app/init.py

 

from flask import Flask
from .views.auto import auto_bp
from .views.motor import motor_bp


def create_app():
    my_app = Flask(__name__) # type:Flask

    my_app.register_blueprint(auto_bp)
    my_app.register_blueprint(motor_bp)

    return my_app

由此见得__init__.py就是构建app的一个函数,并且将views中的似乎是蓝图的东西注册进去了

接下来看static目录,这个目录从字面意思就可以理解了,就是我们的static静态文件存放目录了

然后就是templates目录,模板存放目录

views目录,主角终于登场了,这里存放的就是视图函数文件,也就是我们Blueprint,每一个文件就是一个Blueprint

views/auto.py

1 from flask import Blueprint
2 
3 auto_bp = Blueprint("auto",__name__)
4 
5 @auto_bp.route("/auto")
6 def auto_func():
7     return "my_app.auto"

views/motor.py

1 from flask import Blueprint
2 
3 motor_bp = Blueprint("motor",__name__)
4 
5 @motor_bp.route("/motor")
6 def motor_func():
7     return "my_app.motor"

mnager.py

1 from app import create_app
2 my_app = create_app()
3 
4 if __name__ == '__main__':
5     my_app.run()

 

 

  1. from student import create_app
  2. flask_app = create_app()
  3. flask_app.run("0.0.0.0",5000)

通过这种方式启动 Flask 程序

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

s_list.html 文件中的内容:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>学生列表</title>
  6. </head>
  7. <body>
  8. <table border="3xp">
  9. <thead>
  10. <tr>
  11. <td>ID</td>
  12. <td>name</td>
  13. <td>age</td>
  14. <td>gender</td>
  15. <td>options</td>
  16. </tr>
  17. </thead>
  18. <tbody>
  19. {% for foo in student %}
  20. <tr>
  21. <td>{{ foo.id }}</td>
  22. <td>{{ foo["name"] }}</td>
  23. <td>{{ foo.get("age") }}</td>
  24. <td>{{ foo.gender }}</td>
  25. <td> <a href="/s_update/{{ foo.id }}">修改</a> | <a href="/s_del?id={{ foo.id }}">删除</a> </td>
  26. </tr>
  27. {% endfor %}
  28. </tbody>
  29. </table>
  30. <a href="/s_add"> 添加学生 </a>
  31. </body>
  32. </html>

stu_select.py 文件中的内容:

  1. from flask import Blueprint
  2. from flask import render_template
  3. from student_data import STUDENT
  4. ss_blueprint = Blueprint("ss_b", __name__, template_folder="html", static_folder="static")
  5. @ss_blueprint.route("/s_list")
  6. def s_list():
  7. return render_template("s_list.html", student=STUDENT)

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

  1. from flask import Flask
  2. from student_select import stu_select
  3. def create_app():
  4. app = Flask(__name__) # type:Flask
  5. app.register_blueprint(stu_select.ss_blueprint)
  6. return app

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

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

s_add.html 文件中的内容

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>学生列表</title>
  6. </head>
  7. <body>
  8. <form method="post">
  9. ID:<input type="text" name="id"> <br>
  10. 姓名:<input type="text" name="name"><br>
  11. 年龄:<input type="text" name="age"><br>
  12. 性别:<input type="text" name="gender"><br>
  13. <input type="submit" value="添加学生">
  14. </form>
  15. </body>
  16. </html>

stu_add.py 文件中的内容

  1. from flask import Blueprint
  2. from flask import redirect
  3. from flask import request
  4. from flask import render_template
  5. from student_data import STUDENT
  6. s_add = Blueprint("s_add", __name__, template_folder="html", static_folder="static") # type:Blueprint
  7. @s_add.route("/s_add",methods=["GET","POST"])
  8. def s_add_view():
  9. if request.method == "POST":
  10. stu_dic = {
  11. "id": request.form["id"],
  12. "name": request.form["name"],
  13. "age": request.form["age"],
  14. "gender": request.form["gender"]
  15. }
  16. STUDENT.append(stu_dic)
  17. return redirect("/s_list")
  18. return render_template("s_add.html")

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

student/init.py 文件中的内容

  1. from flask import Flask
  2. from student_select import stu_select
  3. from student_add import stu_add
  4. def create_app():
  5. app = Flask(__name__) # type:Flask
  6. app.register_blueprint(stu_select.ss_blueprint)
  7. app.register_blueprint(stu_add.s_add)
  8. return app

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

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

s_update.html 文件中的内容:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>学生列表</title>
  6. </head>
  7. <body>
  8. <form method="post">
  9. <input type="text" name="id" hidden value="{{ student.id }}"><br>
  10. 姓名:<input type="text" name="name" value="{{ student.name }}"><br>
  11. 年龄:<input type="text" name="age" value="{{ student.age }}"><br>
  12. 性别:<input type="text" name="gender" value="{{ student.gender }}"><br>
  13. <input type="submit" value="修改信息">
  14. </form>
  15. </body>
  16. </html>

stu_update.py 文件中的内容:

  1. from flask import Blueprint
  2. from flask import render_template
  3. from flask import redirect
  4. from flask import request
  5. from student_data import STUDENT
  6. s_update = Blueprint("s_update", __name__, template_folder="html", static_folder="static")
  7. @s_update.route("/s_update/<int:nid>",methods=["GET","POST"])
  8. def s_update_view(nid):
  9. if request.method == "POST":
  10. stu_id = int(request.form["id"])
  11. stu_dic = {
  12. "id": stu_id,
  13. "name": request.form["name"],
  14. "age": request.form["age"],
  15. "gender": request.form["gender"]
  16. }
  17. for index,stu in enumerate(STUDENT):
  18. if stu["id"] == stu_id:
  19. STUDENT[index] = stu_dic
  20. return redirect("/s_list")
  21. for stu in STUDENT:
  22. if stu["id"] == nid :
  23. return render_template("s_update.html", student=stu)
  24. return render_template("s_update.html", student="")

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

  1. from flask import Flask
  2. from student_select import stu_select
  3. from student_add import stu_add
  4. from student_update import stu_update
  5. def create_app():
  6. app = Flask(__name__) # type:Flask
  7. app.register_blueprint(stu_select.ss_blueprint)
  8. app.register_blueprint(stu_add.s_add)
  9. app.register_blueprint(stu_update.s_update)
  10. return app

试一下结果:

删除自己做吧..

5. 蓝图目录

app/init.py

  1. 1 from flask import Flask
  2. 2 from .views.auto import auto_bp
  3. 3 from .views.motor import motor_bp
  4. 4
  5. 5
  6. 6 def create_app():
  7. 7 my_app = Flask(__name__) # type:Flask
  8. 8
  9. 9 my_app.register_blueprint(auto_bp)
  10. 10 my_app.register_blueprint(motor_bp)
  11. 11
  12. 12 return my_app

由此见得__init__.py就是构建app的一个函数,并且将views中的似乎是蓝图的东西注册进去了

接下来看static目录,这个目录从字面意思就可以理解了,就是我们的static静态文件存放目录了

然后就是templates目录,模板存放目录

views目录,主角终于登场了,这里存放的就是视图函数文件,也就是我们Blueprint,每一个文件就是一个Blueprint

views/auto.py

  1. 1 from flask import Blueprint
  2. 2
  3. 3 auto_bp = Blueprint("auto",__name__)
  4. 4
  5. 5 @auto_bp.route("/auto")
  6. 6 def auto_func():
  7. 7 return "my_app.auto"

views/motor.py

  1. 1 from flask import Blueprint
  2. 2
  3. 3 motor_bp = Blueprint("motor",__name__)
  4. 4
  5. 5 @motor_bp.route("/motor")
  6. 6 def motor_func():
  7. 7 return "my_app.motor"

mnager.py

  1. 1 from app import create_app
  2. 2 my_app = create_app()
  3. 3
  4. 4 if __name__ == '__main__':
  5. 5 my_app.run()
 
分类:  Flask
 
好文要顶  关注我  收藏该文   
 
 
+加关注
0
0
 
 
 
« 上一篇: Flask - 路由系统
» 下一篇: Flask - 特殊装饰器 和 Flask工作结构模式(FBV, CBV)
posted @  2019-03-21 21:52  孔辉 阅读( 6) 评论( 0编辑  收藏
 

转载于:https://www.cnblogs.com/lw1095950124/p/10956349.html

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Monodyee/article/detail/592644
推荐阅读
相关标签
  

闽ICP备14008679号