Bootstrap

Django-信号

信号介绍

Django有一个“信号调度器(signal dispatcher)”,当框架中的其他地方发生操作时,它可以通知一些解耦的应用程序

官网:信号 | Django 文档 | Django

内置的信号的使用

定义接收器函数

在子应用创建信号.py文件 创建接收器函数

def my_callback(sender, **kwargs):
  print("Request finished!")

该函数接收一个 sender 参数以及关键字参数 (**kwargs);所有信号处理程序都必须接受这些参数

链接接收器

方法1:使用django.core.signals里面的事件进行链接

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)

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 的实例

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")

;