zoukankan      html  css  js  c++  java
  • Flask【第九章】:Flask之蓝图

    Flask之蓝图

    蓝图听起来就是一个很宏伟的东西,在Flask中的蓝图blueprint也是非常宏伟的,它的作用就是将功能与主服务分开,就像Django中的app应用一样。也可以把blueprint当成一个不能被启动的Flask实例

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

    一、初始Flask蓝图(blueprint)

    创建一个项目,然后在项目中创建一个蓝图(应用),目录结构如下:

    view01.py文件中的内容:

    from flask import Blueprint  # 导入 Flask 中的蓝图 Blueprint 模块
    ap1 = Blueprint("ap1",__name__)  #实例化一个蓝图对象

    @ap1.route(
    "/ap1list") #这里添加路由和视图函数的时候与在flask对象中添加是一样的
    def view_list():
    return "this is ap1"

    f1.py文件中的内容:

    from flask import Flask
    from app01 import view01  #导入此前写好的蓝图模块
    
    app = Flask(__name__)  #type:Flask
    
    app.register_blueprint(view01.ap1) #在Flask对象中注册蓝图模块中的蓝图对象view01中的ap1
    
    app.run("0.0.0.0",5000,debug=True) 

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

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

    二、如果理解蓝图呢?

    其实我们可以理解成一个没有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不要出现重复,否则~你们自己试试吧

    三、使用蓝图做一个增删改查用户

  • 相关阅读:
    【Selenium-WebDriver问题点】chromeDriver和chrome浏览器版本之间的兼容性问题
    【Linux】【Jmeter】配置Jmeter服务器和运行Jmeter
    【Linux】【JDK】常用命令使用集和裸机配置JDK步骤。
    【Linux】使用ZStack私有云创建本地Linux服务器
    js基本数据类型和typeof
    Javascript 面向对象编程
    css3作3D旋转视频展示
    css3中的border-radius
    css3中做3D导航栏
    css3动画学习笔记
  • 原文地址:https://www.cnblogs.com/zhangjunkang/p/10240197.html
Copyright © 2011-2022 走看看