蓝图Blueprint
---恢復(fù)內(nèi)容開始---
藍(lán)圖: flask模塊化處理操作和URL的方式
作用:
使用步驟
代碼操作
通過目錄式結(jié)構(gòu)定義藍(lán)圖
?
?
1.簡單版
項目文件夾-模塊文件夾-模塊文件, __init__.py
from flask import Blueprint# 1.創(chuàng)建藍(lán)圖 goods_dp = Blueprint('goods', __name__)# 3.和views關(guān)聯(lián)起來,導(dǎo)入views.py 放在此處導(dǎo)入是延遲導(dǎo)入解決循環(huán)導(dǎo)入問題 from .views import *項目文件夾-模塊文件夾-模塊文件, views.py
from goods import goods_dp# 2.使用藍(lán)圖 @goods_dp.route('/goods/info') def goods():"""商品視圖函數(shù)"""return 'goods'項目文件夾下項目文件demo1.py
from flask import Flask from goods import goods_dpapp = Flask(__name__)# 4.注冊藍(lán)圖 app.register_blueprint(goods_dp)if __name__ == '__main__':print(app.url_map)app.run(debug=True)?2.加強版, 一般大致是以下這種
項目文件下templates文件夾, 按不同模塊建立不同文件夾, 如此處的goods文件夾; goods文件夾下建立HTML文件
goods.HTML里面放入需要添加的內(nèi)容, 演示只簡單操作如下
<!DOCTYPE html> <html lang="en"> <head><meta charset="UTF-8"><title>Title</title> </head> <body><h1>商品模塊</h1></body> </html>1中的代碼做下面更改
- views.py做以下更改
導(dǎo)入模塊 from flask import render_template
返回語句return render_template("goods/goods.html")
from goods import goods_dp from flask import render_template# 2.使用藍(lán)圖 @goods_dp.route('/goods/info') def goods():"""商品視圖函數(shù)"""return render_template("goods/goods.html")運行demo1文件后, 此時瀏覽器訪問127.0.0.1:5000/goods/info, 可以網(wǎng)頁顯示? 商品模塊
?
- 上面views.py中的代碼繼續(xù)更改:
把路徑中的goods去掉放入__init__.py文件
from goods import goods_dp from flask import render_template# 2.使用藍(lán)圖 @goods_dp.route('/info') def goods():"""商品視圖函數(shù)"""return render_template("goods/goods.html")- __init__.py文件更改
加入前綴url_profix, 在藍(lán)圖上注冊的路由URL自動被加上了這個前綴,這個可以保證在多個藍(lán)圖中使用相同的URL規(guī)則而不會最終引起沖突,只要在注冊藍(lán)圖時將不同的藍(lán)圖掛接到不同的自路徑即可
from flask import Blueprint# 1.創(chuàng)建藍(lán)圖 goods_dp = Blueprint('goods', __name__, url_prefix="/goods")# 3.和views關(guān)聯(lián)起來,導(dǎo)入views.py 放在此處導(dǎo)入是延遲導(dǎo)入解決循環(huán)導(dǎo)入問題 from .views import *?
轉(zhuǎn)載于:https://www.cnblogs.com/taocc/p/9720042.html
總結(jié)
以上是生活随笔為你收集整理的蓝图Blueprint的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 海藻酸含量测定用的是什么显色剂?
- 下一篇: ASP.NET Core macOS 环