Django框架 之 信號
阿新 • • 發佈:2018-07-07
pre 配置 定義 內置 response pri top 分享圖片 oda
Django中提供了“信號調度”,用於在框架執行操作時解耦。通俗來講,就是一些動作發生的時候,信號允許特定的發送者去提醒一些接受者。
Django內置信號
Model signals pre_init # django的modal執行其構造方法前,自動觸發 post_init # django的modal執行其構造方法後,自動觸發 pre_save # django的modal對象保存前,自動觸發 post_save # django的modal對象保存後,自動觸發 pre_delete # django的modal對象刪除前,自動觸發 post_delete # django的modal對象刪除後,自動觸發 m2m_changed # django的modal中使用m2m字段操作第三張表(add,remove,clear)前後,自動觸發 class_prepared # 程序啟動時,檢測已註冊的app中modal類,對於每一個類,自動觸發 Management signals pre_migrate # 執行migrate命令前,自動觸發 post_migrate # 執行migrate命令後,自動觸發 Request/response signals request_started # 請求到來前,自動觸發 request_finished # 請求結束後,自動觸發 got_request_exception # 請求異常後,自動觸發 Test signals setting_changed # 使用test測試修改配置文件時,自動觸發 template_rendered # 使用test測試渲染模板時,自動觸發 Database Wrappers connection_created # 創建數據庫連接時,自動觸發
對於Django內置的信號,僅需註冊指定信號,當程序執行相應操作時,自動觸發註冊函數:
#在model表中添加/刪除記錄時執行響應的方法 from django.db.models import signals def before_save1(*args,**kwargs): print(‘有車來了,我要服務了--》‘,args,kwargs) def before_save2(*args,**kwargs): print(‘有車來了,我要服務了--》‘,args,kwargs) def after_save1(*args,**kwargs):示例print(‘有車來了,完事了--》‘,args,kwargs) signals.pre_save.connect(before_save1) signals.pre_save.connect(before_save2) signals.post_save.connect(after_save1)
自定義信號
定義信號
import django.dispatch pizza_done = django.dispatch.Signal(providing_args=["toppings", "size"])
註冊信號
def callback(sender, **kwargs): print("callback") print(sender,kwargs) pizza_done.connect(callback)
觸發信號
from 路徑 import pizza_done pizza_done.send(sender=‘seven‘,toppings=123, size=456)
由於內置信號的觸發者已經集成到Django中,所以其會自動調用,而對於自定義信號則需要開發者在任意位置觸發。
Django框架 之 信號