django——signal
其实可以理解为django内部的钩子,当某一个事件发生时,其它程序会触发并对其作出相关反应,通过signal回调处理函数(receivers),从而更大程度的解耦我们的项目
- 导入类库
from django.shortcuts import render
from django.http import HttpResponse
from django.core.signals import request_finished,request_started,got_request_exception
from django.dispatch import receiver
from django.dispatch.dispatcher import Signal
from django.db.models import signals
from django.db.models.signals import pre_save,pre_delete
from django.db.models.base import Model
import django.dispatch
from app.models import SomeModel Django内置信号
@receiver(request_started)
def requeststarted(sender,**kwargs):
print(sender,'这是request_started')
request_started.connect(requeststarted)#请求完成信号
- 内置信号触发方式
- 先定义信号激活时要触发的函数,然后用 信号类型名.connect(函数名),即可达到与第二种装饰器方法相同的效果
-
一个receiver装饰器,里面第一个参数放信号的类型,第二个参数放附加参数,然后装饰信号激活时要触发的函数
@receiver(pre_save) #model保存信号
def presave(sender,**kwargs):
print(sender,'这是pre_save') @receiver(pre_delete) #model删除信号
def predelete(sender,**kwargs):
print(sender,'这是pre_delete')
- 自定义信号
没有内置这种信号,用户可自定义,与内置信号使用的第一种方法相同
bus_comming = django.dispatch.Signal(providing_args=['plate_numbers']) def callback(sender,**kwargs):
print(sender,kwargs,'这是自定义信号') bus_comming.connect(callback)
bus_comming.send(sender='lijingbo',plate_numbers=666)