關於flask藍圖

首選:flask藍圖是什麼?

flask運行web程序的運行是通過實例化對象app.run()來運行的,那麼會出現在一個.py文件裏面定義很多的視圖函數,即不方便代碼管理,又不利於後期的維護.所以在flask出現了藍圖(Blueprint),可以使程序模塊化,就像django的一個個模塊一樣來獨立編程。那麼這個藍圖(Blueprint)就實現了這個功能。
簡單來說,Blueprint 是一個存儲操作方法的容器,這些操作在這個Blueprint 被註冊到一個應用之後就可以被調用,Flask 可以通過Blueprint來組織URL以及處理請求。Flask使用Blueprint讓應用實現模塊化。

在Flask中,Blueprint具有如下屬性:

一個應用可以具有多個Blueprint
可以將一個Blueprint註冊到任何一個未使用的URL下比如 “/”、“/sample”或者子域名
在一個應用中,一個模塊可以註冊多次
Blueprint可以單獨具有自己的模板、靜態文件或者其它的通用操作方法,它並不是必須要實現應用的視圖和函數的
在一個應用初始化時,就應該要註冊需要使用的Blueprint
但是一個Blueprint並不是一個完整的應用,它不能獨立於應用運行,而必須要註冊到某一個應用中。

運行機制

藍圖是保存了一組將來可以在應用對象上執行的操作,註冊路由就是一種操作
當在應用對象上調用 route 裝飾器註冊路由時,這個操作將修改對象的url_map路由表
然而,藍圖對象根本沒有路由表,當我們在藍圖對象上調用route裝飾器註冊路由時,它只是在內部的一個延遲操作記錄列表defered_functions中添加了一個項
當執行應用對象的 register_blueprint() 方法時,應用對象將從藍圖對象的 defered_functions 列表中取出每一項,並以自身作爲參數執行該匿名函數,即調用應用對象的 add_url_rule() 方法,這將真正的修改應用對象的路由表。

藍圖的url前綴

當我們在應用對象上註冊一個藍圖時,可以指定一個url_prefix關鍵字參數(這個參數默認是/)
在應用最終的路由表 url_map中,在藍圖上註冊的路由URL自動被加上了這個前綴,這個可以保證在多個藍圖中使用相同的URL規則而不會最終引起衝突,只要在註冊藍圖時將不同的藍圖掛接到不同的自路徑即可。

註冊靜態路由

和應用對象不同,藍圖對象創建時不會默認註冊靜態目錄的路由。需要我們在 創建時指定 static_folder 參數。
下面的示例將藍圖所在目錄下的static_admin目錄設置爲靜態目錄

admin = Blueprint("admin",__name__,static_folder='static_admin')
app.register_blueprint(admin,url_prefix='/admin')

現在就可以使用/admin/static_admin/ 訪問static_admin目錄下的靜態文件了 定製靜態目錄URL規則 :可以在創建藍圖對象時使用 static_url_path 來改變靜態目錄的路由。下面的示例將爲static_admin文件夾的路由設置爲 /lib

admin = Blueprint("admin",__name__,static_folder='static_admin',static_url_path='/lib')
app.register_blueprint(admin,url_prefix='/admin')

設置模版目錄

藍圖對象默認的模板目錄爲系統的模版目錄,可以在創建藍圖對象時使用 template_folder 關鍵字參數設置模板目錄

admin = Blueprint('admin',__name__,template_folder='my_templates')

注:如果在templates中存在和my_templates同名文件,則系統會優先使用templates中的文件,在使用templates目錄同名的情況下,需要通過路徑區分,例如:

my_templates存在兩個,若使用admin目錄下的my_templates目錄,則需要使用如下方式註冊:

admin = Blueprint('admin',__name__,template_folder='admin/my_templates')
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章