• [py]flask蓝图的使用


    参考

    flask挺挺轻巧的, 因此玩一玩它. 如果用它做大型点的项目, 就用到了它的蓝图组织项目. 一时半会不太清楚这玩意怎么用, 得撸一撸py基础了.

    我搞了个movie小的flask栗子来用用蓝图小功能, git地址如下.
    项目分前台 home, 后台admin模块.使用蓝图来组织.

    https://github.com/lannyMa/movie

    首先,我对蓝图的理解相对通俗,就是觉得蓝图对于视图方法模块化、大项目协同开发过程中的一个很好的工具.

    1.下图是我们通常情况下使用的项目组织结构


    看一下视图方法:

    #views.py
    from app import app
    
    
    @app.route('/user/index')
    def index():
        return 'user_index'
    
    @app.route('/user/show')
    def show():
        return 'user_show'
    
    @app.route('/user/add')
    def add():
        return 'user_add'
    
    @app.route('/admin/index')
    def adminindex():
        return 'admin_index'
    
    @app.route('/admin/show')
    def adminshow():
        return 'admin_show'
    
    @app.route('/admin/add')
    def adminadd():
        return 'admin_add'
    

    从视图方法中,我们看到有6个视图,分别对应admin,user两个不同用户的3个功能index,add,show.
    这样写显然没问题,但是明显与python提倡的模块化,优雅的代码特点相违背,即不是很python的python代码.

    让我们在这里假想两个问题:

    • 1.如果admin和user不止只有3个功能呢,比如好几百个,导致views的代码量已经达到了上万行?
    • 2.如果我们有多个同事分工开发admin,user和其它可能的模块呢,都同时往一个views里写代码吗,在做版本控制时,提交过程中频繁出现提交冲突了怎么办?
    • 3.加入我们要抛弃admin或者user功能块时怎么办,要一一手动删除所有admin或是user相关的代码吗,这样当然可以,但是会不会太low呢?

    当然根据Pythonic特点,我们肯定希望尽可能的把代码尽量的模块化,让我们的代码看起来更加的优雅和顺畅,这个时候flask.Blueprint(蓝图)就派上用场了

    什么是蓝图?

    一个蓝图定义了可用于单个应用的视图,模板,静态文件等等的集合。

    我什么时候会用到蓝图?

    蓝图的杀手锏是将你的应用组织成不同的组件,比如把这里的admin,user相关的视图方法分为两个组件,一个是admin组件,一个是user组件.这时我们可以

    创建两个蓝图实现这两个独立的组件.

    2.我们如何使用蓝本将上述的视图方法看上去更加pythonic呢?

    由于上面的例子中只有两个组件(模块)admin,user,我们可以创建名为admin.py和user.py的两个文件,分别在里面创建两个蓝图的实例对象admin,user.

    直接上代码:

    #admin.py
    from flask import Blueprint,render_template, request
    
    admin = Blueprint('admin',__name__)
    
    @admin.route('/index')
    def index():
        return render_template('admin/index.html')
    
    @admin.route('/add')
    def add():
        return 'admin_add'
    
    @admin.route('/show')
    def show():
        return 'admin_show'
    

    要想创建一个蓝图对象,你需要import flask.Blueprint()类并用参数name和import_name初始化。import_name通常用__name__,一个表示当前模块的特殊的Python变量,作为import_name的取值。

    #user.py
    from flask import Blueprint, render_template, redirect
    
    user = Blueprint('user',__name__)
    
    @user.route('/index')
    def index():
        return render_template('user/index.html')
    
    @user.route('/add')
    def add():
        return 'user_add'
    
    @user.route('/show')
    def show():
        return 'user_show'
    

    好了,视图函数已经分开了,我们如何使用它们的呢?再来看一下我们的views.py变成了什么样吧?

    #views.py
    from app import app
    from .admin import admin
    from .user import user
    
    #这里分别给app注册了两个蓝图admin,user
    #参数url_prefix='/xxx'的意思是设置request.url中的url前缀,
    #即当request.url是以/admin或者/user的情况下才会通过注册的蓝图的视图方法处理请求并返回
    app.register_blueprint(admin,url_prefix='/admin')
    app.register_blueprint(user, url_prefix='/user')
    
    • 现在我们的views是否已经变得很简单了呢?顺便回答第三个问题,如果想弃用某一个组件(模块)我们只需要相对应的注释掉给app注册蓝图的行即可.

    • 细心的伙伴还可以发现,在views.py中在使用默认endpoint的前提下,我们是没有办法使用同一个视图方法名的(当然我们也不建议在同一个文件中有两个视图方法名相同,

    • 尽管指向他们的request.url不同),但是使用了蓝图之后我们就可以在不同模块中使用相同的方法名了,例如add,show..

    3.到此我们就可以通过浏览器测试我们的程序


    4.附上使用蓝图后的项目组织结构

    当然如果项目不大的话就没有什么必要使用蓝图了,甚至我们可以把除了所有css,js,html的代码都写到一个文件中去,这里我们不在举例,说明.

  • 相关阅读:
    原生js,实现跨越的jsonp
    nodejs+express+jade安装步骤
    浏览器端创建可下载文件
    保留有效数字
    日期转换格式
    js添加千分位
    vue 中的 全选和 反选
    防止域名被恶意解析
    node命令行工具之实现项目工程自动初始化的标准流程
    React router动态加载组件-适配器模式的应用
  • 原文地址:https://www.cnblogs.com/iiiiiher/p/8370913.html
Copyright © 2020-2023  润新知