Django信号Django中提供了“信号调度”,用于在框架执行操作时解耦。通俗来讲,就是一些动作发生的时候,信号允许特定的发送者去提醒一些接受者。 1、Django内置信号?
对于Django内置的信号,仅需注册指定信号,当程序执行相应操作时,自动触发注册函数: 注册信号,写入与project同名的文件夹下的_init_.py文件中,也是换数据库引擎的地方。 ![]() from django.core.signals import request_finished from django.core.signals import request_started from django.core.signals import got_request_exception from django.db.models.signals import class_prepared from django.db.models.signals import pre_init, post_init from django.db.models.signals import pre_save, post_save from django.db.models.signals import pre_delete, post_delete from django.db.models.signals import m2m_changed from django.db.models.signals import pre_migrate, post_migrate from django.test.signals import setting_changed from django.test.signals import template_rendered from django.db.backends.signals import connection_created def callback(sender, **kwargs): print("xxoo_callback") print(sender,kwargs) xxoo.connect(callback) # xxoo指上述导入的内容View Code ![]() def my_callback(sender, **kwargs): print("Request finished!") # 方法一: from django.core.signals import request_finished request_finished.connect(my_callback) # 方法二: from django.core.signals import request_finished from django.dispatch import receiver @receiver(request_finished) def my_callback(sender, **kwargs): print("Request finished!")示例 ![]() from django.db.models.signals import pre_save from django.dispatch import receiver from myapp.models import MyModel @receiver(pre_save, sender=MyModel) def my_handler(sender, **kwargs): ...指定发送者 2、自定义信号a. 定义信号 在某py文件中定义信号。 ?
b. 注册信号 在_init_.py 中注册信号 ?
c. 触发信号 ?
由于内置信号的触发者已经集成到Django中,所以其会自动调用,而对于自定义信号则需要开发者在任意位置触发。 更多:猛击这里 序列化关于Django中的序列化主要应用在将数据库中检索的数据返回给客户端用户,特别的Ajax请求一般返回的为Json格式。 1、serializers ?
2、json.dumps ?
由于json.dumps时无法处理datetime日期,所以可以通过自定义处理器来做扩展,如: View Code?
|
|