蓝图Blueprint

时间:2021-01-16 23:39:21

---恢复内容开始---

蓝图: flask模块化处理操作和URL的方式

作用:

  1. 将不同的功能模块化,实现模块化应用
  2. 构建大型应用
  3. 优化项目结构

使用步骤

  1. 创建蓝图对象
  2. 对蓝图对象进行操作(注册路由; 指定静态文件夹; 注册模板过滤器)
  3. 在应用对象上注册蓝图对象

代码操作

通过目录式结构定义蓝图

蓝图Blueprint

1.简单版

项目文件夹-模块文件夹-模块文件, __init__.py

from flask import Blueprint

# 1.创建蓝图
goods_dp = Blueprint('goods', __name__) # 3.和views关联起来,导入views.py 放在此处导入是延迟导入解决循环导入问题
from .views import *

项目文件夹-模块文件夹-模块文件, views.py

from goods import goods_dp

# 2.使用蓝图
@goods_dp.route('/goods/info')
def goods():
"""商品视图函数"""
return 'goods'

项目文件夹下项目文件demo1.py

from flask import Flask
from goods import goods_dp app = Flask(__name__) # 4.注册蓝图
app.register_blueprint(goods_dp) if __name__ == '__main__':
print(app.url_map)
app.run(debug=True)

2.加强版, 一般大致是以下这种

项目文件下templates文件夹, 按不同模块建立不同文件夹, 如此处的goods文件夹; goods文件夹下建立HTML文件

goods.HTML里面放入需要添加的内容, 演示只简单操作如下

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<h1>商品模块</h1> </body>
</html>

1中的代码做下面更改

  • views.py做以下更改

  导入模块 from flask import render_template

  返回语句return render_template("goods/goods.html")

from goods import goods_dp
from flask import render_template # 2.使用蓝图
@goods_dp.route('/goods/info')
def goods():
"""商品视图函数"""
return render_template("goods/goods.html")

运行demo1文件后, 此时浏览器访问127.0.0.1:5000/goods/info, 可以网页显示  商品模块


  • 上面views.py中的代码继续更改:

  把路径中的goods去掉放入__init__.py文件

from goods import goods_dp
from flask import render_template # 2.使用蓝图
@goods_dp.route('/info')
def goods():
"""商品视图函数"""
return render_template("goods/goods.html")
  • __init__.py文件更改

加入前缀url_profix, 在蓝图上注册的路由URL自动被加上了这个前缀,这个可以保证在多个蓝图中使用相同的URL规则而不会最终引起冲突,只要在注册蓝图时将不同的蓝图挂接到不同的自路径即可

from flask import Blueprint

# 1.创建蓝图
goods_dp = Blueprint('goods', __name__, url_prefix="/goods") # 3.和views关联起来,导入views.py 放在此处导入是延迟导入解决循环导入问题
from .views import *