信号介绍
Django有一个"信号调度器(signal dispatcher)",当框架中的其他地方发生操作时,它可以通知一些解耦的应用程序
内置的信号的使用
定义接收器函数
在子应用创建信号.py文件 创建接收器函数
python
def my_callback(sender, **kwargs):
print("Request finished!")
该函数接收一个 sender
参数以及关键字参数 (**kwargs
);所有信号处理程序都必须接受这些参数
链接接收器
方法1:使用django.core.signals
里面的事件进行链接
python
from django.core.signals import request_finished
from .信号 import my_callback
# dispatch_uid 为了防止重复信号,给一个唯一的字符串即可,一般是信号名+接口函数
request_finished.connect(my_callback, dispatch_uid="my_unique_identifier")
方法2:使用装饰器django.dispatch.receiver(signal,**kwargs)
python
from django.core.signals import request_finished
from django.dispatch import receiver
@receiver(request_finished,dispatch_uid="my_unique_identifier")
def my_callback(sender, **kwargs):
print("Request finished!")
严格来说,信号处理和注册的代码可以放在任何地方,最好避免放在应用程序的根目录和 models
模块内以尽量减少导入代码的副作用。
自定义信号
所有的信号都是 django.dispatch.Signal 的实例
python
import django.dispatch
from django.dispatch import receiver
pizza_done = django.dispatch.Signal() # 创建信号
# 定义接收器和链接信号
@receiver(pizza_done)
def my_callback(sender, **kwargs):
print("Request finished!")
view.py文件中
impor 信号
def index(requsest):
信号.send(sender='名字')
return HttpRespone("xxxxx")