蓝图的使用
- 1.目录结构:
app1: 单个应用的目录
app1/admin: app1下的一个功能模块
app1/admin/templates: 存放实现admin功能的模板文件
app1/admin/urls.py: 类似Django的urls,设置路由(此处创建admin专属的路由)
app1/admin/views.py: 模板渲染文件,类似Django的views
templates/index.html: 项目入口(或链接各个应用)的模板文件
apps.py: 创建Flask-app对象;注册蓝图,为蓝图添加前缀;启动应用
- 2.文件内容
1.app1/admin/templates/index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Admin</title>
</head>
<body>
<h1>Admin</h1>
</body>
</html>
2.app1/admin/views.py
- 渲染模板文件
from flask import render_template
def show_admin():
return render_template('index.html')
3.app1/admin/urls.py
- 注册蓝图admin,指明模板文件,添加蓝图路由
from flask import Blueprint
from .views import *
admin = Blueprint('admin', __name__, template_folder='admin_templates')
admin.add_url_rule('/show_admin/', view_func=show_admin)
4.apps.py
- 创建Flask-app对象;注册蓝图,为蓝图添加前缀;启动应用
from flask import Flask
app1 = Flask(__name__)
from app1.admin.urls import admin
app1.register_blueprint(admin, url_prefix='/admin')
if __name__ == '__main__':
app1.run(debug=True)
文件访问
- 通过蓝图注册的静态文件及模板文件的访问规则如下:
1.如果在项目目录下存在静态文件和模板文件,则优先访问
- manage_test/templates/index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>首页</title>
</head>
<body>
<h1>首页</h1>
</body>
</html>
- app1/admin/templates/index.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Admin</title>
</head>
<body>
<h1>Admin</h1>
</body>
</html>
- app1/admin/urls.py 创建蓝图对象admin,在manage_test/app.py中注册
from flask import Blueprint
from .views import *
admin = Blueprint('admin', __name__,
static_folder='static',
template_folder='templates')
admin.add_url_rule('/show_index/',
view_func=show_admin)
- app1/admin/views.py 渲染网页
from flask import render_template
def show_admin():
return render_template('index.html')
- manage_test/apps.py 创建app对象及注册蓝图
from flask import Flask
app1 = Flask(__name__)
from app1.admin.urls import admin
app1.register_blueprint(admin, url_prefix='/admin')
if __name__ == '__main__':
app1.run(debug=True)
- 运行apps.py,打开浏览器显示结果如下
2.如果项目目录下不存在静态文件和模板文件,则优先访问最先注册的蓝图目录下的文件
-
1.删除manage_test/templates/index.html
- 此时刷新网页显示结果如下:
-
2.创建grade文件夹,里面也创建一个templates文件夹及index.html文件
- app1/grade/views.py
from flask import render_template def show_index(): return render_template('index.html')
- urls.py
from flask import Blueprint from .views import * grade = Blueprint('grade', __name__, static_folder='static', template_folder='templates') grade.add_url_rule('/show_index/', view_func=show_index)
- manage_test/apps.py 新增一个蓝图grade的注册
from flask import Flask app1 = Flask(__name__) from app1.admin.urls import admin from app1.grade.urls import grade app1.register_blueprint(grade, url_prefix='/grade') app1.register_blueprint(admin, url_prefix='/admin') if __name__ == '__main__': app1.run(debug=True)
- 此时刷新网页:
admin/show_index
grade/show_index
Tip:
- 使用flask蓝图设置路由时需要注意静态文件和模板文件不能同名
推荐做法一: 在每个功能模块下的静态和模板文件夹下再创建一个与应用同名的文件夹
- 修改admin/views.py
return render_template('admin/index.html')
此时admin/show_index显示:
推荐做法二: 每个模块在创建文件夹时加上模块名
admin_templates
(当然如果是小组开发,也可以使用代号LZ_templates
)
推荐做法三: 根据模板文件的功能命名,确保不会与其他模块重名
issue
ValueError: urls must start with a leading slash
蓝图在注册添加前缀时没有加'/'