蓝图
2020-05-30 本文已影响0人
i_1312
蓝图可以把实现不同功能的module分开.也就是把一个大的App分割成各自实现不同功能的module. 我们看一个简单得例子,比如一个系统分为了用户端和管理员端,简单得写法就是:
#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提倡的模块化冲突,们肯定希望尽可能的把代码尽量的模块化,让我们的代码看起来更加的优雅和顺畅,这个时候flask.Blueprint(蓝图)就派上用场了。
上面得例子有两个组件(模块)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'
视图函数已经分开了 再看看view.py
#view.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')
如果项目不大的话就没有必要使用蓝图了,我们甚至可以把除了所有css,js,html的代码都写到一个文件中去。