婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 正確的理解和使用Django信號(Signals)

正確的理解和使用Django信號(Signals)

熱門標簽:看懂地圖標注方法 佛山通用400電話申請 京華圖書館地圖標注 蘇州人工外呼系統軟件 電話機器人貸款詐騙 淮安呼叫中心外呼系統如何 打印谷歌地圖標注 廣東旅游地圖標注 電話外呼系統招商代理

Django 提供一個了“信號分發器”機制,允許解耦的應用在框架的其它地方發生操作時會被通知到。 通俗而講Django信號的工作原理就是當某個事件發生的時候會發出一個信號(signals), 而監聽這個信號的函數(receivers)就會立即執行。Django信號的應用場景很多,尤其是用于不同模型或程序間的聯動。常見例子包括創建User對象實例時創建一對一關系的UserProfile對象實例,或者每當用戶下訂單時觸發給管理員發郵件的動作。今天小編我就分享下如何正確使用Django的信號(signals)。

Django信號的一個簡單例子

假設我們有一個如下User模型,我們希望每次有User對象新創建時都打印出有新用戶注冊的提示信息,我們可以使用Django信號(signals)輕松實現。我們的信號發送者sender是User模型,每當User模型執行post_save動作時就會發出信號。此時我們自定義的create_user函數一旦監聽到User發出的post_save信號就會執行,先通過if created判斷對象是新創建的還是被更新的;如果對象是新創建的,就會打印出提示信息。

# models.py

from django.db import models

from django.db.models import signals
from django.dispatch import receiver

class User(models.Model):
    name = models.CharField(max_length=16)
    gender = models.CharField(max_length=32, blank=True)

def create_user(sender, instance, created, **kwargs):

    if created:

        print("New user created!")

post_save.connect(create_user, sender=User)

在上例中我們使用了信號(post_save)自帶的connect的方法將自定義的函數與信號發出者(sender)User模型進行了連接。在實際應用中一個更常用的方式是使用@receiver裝飾器實現發送者與監聽函數的連接,如下所示。@receiver(post_save, sender=User)讀起來的意思就是監聽User模型發出的post_save信號。

from django.db import models

from django.db.models.signals import post_save
from django.dispatch import receiver

class User(models.Model):
    name = models.CharField(max_length=16)
    gender = models.CharField(max_length=32, blank=True)

@receiver(post_save, sender=User)
def create_user(sender, instance, created, **kwargs):

    if created:

        print("New user created!")

利用Django信號實現不同模型的聯動更新

我們再來看一個復雜一點的例子。我們有一個Profile模型,與User模型是一對一的關系。我們希望創建User對象實例時也創建Profile對象實例,而使用post_save更新User對象時不創建新的Profile對象。這時我們就可以自定義create_user_profile和save_user_profile兩個監聽函數,同時監聽sender(User模型)發出的post_save信號。由于post_save可同時用于模型的創建和更新,我們用if created這個判斷來加以區別。

from django.db import models
from django.db.models.signals import post_save
from django.dispatch import receiver

class Profile(models.Model):
    user = models.OneToOneField(User, on_delete=models.CASCADE)
    birth_date = models.DateField(null=True, blank=True)

@receiver(post_save, sender=User)
def create_user_profile(sender, instance, created, **kwargs):
   if created:
       Profile.objects.create(user=instance)

@receiver(post_save, sender=User)
def save_user_profile(sender, instance, **kwargs):
    instance.profile.save()

Django常用內置信號

之前的例子中我們使用的都是post_save信號,即在模型調用save()方法后才發送信號。Django其它常用內置信號還包括:

  • django.db.models.signals.pre_save post_save在模型調用 save()方法之前或之后發送。
  • django.db.models.signals.pre_init post_init在模型調用_init_方法之前或之后發送。
  • django.db.models.signals.pre_delete post_delete在模型調用delete()方法或查詢集調用delete() 方法之前或之后發送。
  • django.db.models.signals.m2m_changed在模型多對多關系改變后發送。
  • django.core.signals.request_started request_finished Django建立或關閉HTTP 請求時發送。

如何正確放置Django信號的監聽函數代碼

在之前案例中,我們將Django信號的監聽函數寫在了models.py文件里。當一個app的與信號相關的自定義監聽函數很多時,此時models.py代碼將變得非常臃腫。一個更好的方式把所以自定義的信號監聽函數集中放在app對應文件夾下的signals.py文件里,便于后期集中維護。

假如我們有個account的app,包含了User和Pofile模型,我們不僅需要在account文件夾下新建signals.py,還需要修改account文件下apps.py和__init__.py,以導入創建的信號監聽函數。

# account/signals.py

from django.db.models.signals import post_save
from django.dispatch import receiver
from .models import User, Profile



@receiver(post_save, sender=User)

def create_user_profile(sender, instance, created, **kwargs):

  if created:

      Profile.objects.create(user=instance)



@receiver(post_save, sender=User)

def save_user_profile(sender, instance, **kwargs):

    instance.profile.save()

# account/apps.py

from django.apps import AppConfig

class AccountConfig(AppConfig):
    name = 'account'

    def ready(self):
        import account.signals

# account/__init__.py

default_app_config = 'account.apps.AccountConfig'

小結

在本文里我們總結了Django信號(signals)的工作原理,介紹了如何使用Django信號實現模型或程序的聯動。最后我們還總結了Django常用內置信號以及如何正確放置自定義的信號監聽函數。歡迎關注我們更多Python Web開發和Django原創文章。

以上就是正確的理解和使用Django信號(Signals)的詳細內容,更多關于Django信號(Signals)的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • 3分鐘看懂Python后端必須知道的Django的信號機制
  • 基于Django signals 信號作用及用法詳解
  • Django框架 信號調度原理解析
  • django 信號調度機制詳解
  • Django中信號signals的簡單使用方法
  • 深入理解Django-Signals信號量
  • 深入理解Django自定義信號(signals)
  • 利用信號如何監控Django模型對象字段值的變化詳解
  • Django的信號機制詳解

標簽:股票 呼和浩特 衡水 江蘇 湖州 駐馬店 畢節 中山

巨人網絡通訊聲明:本文標題《正確的理解和使用Django信號(Signals)》,本文關鍵詞  正確,的,理解,和,使用,Django,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《正確的理解和使用Django信號(Signals)》相關的同類信息!
  • 本頁收集關于正確的理解和使用Django信號(Signals)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 贺州市| 葫芦岛市| 横峰县| 毕节市| 高雄县| 南陵县| 闽清县| 炎陵县| 昂仁县| 含山县| 龙游县| 剑河县| 江华| 哈尔滨市| 大兴区| 工布江达县| 怀化市| 花垣县| 温泉县| 汉寿县| 门源| 彰化县| 崇明县| 博白县| 青海省| 平泉县| 林周县| 乌拉特后旗| 潞城市| 道真| 德令哈市| 瓮安县| 清丰县| 和田市| 渝北区| 印江| 邵武市| 花莲市| 长泰县| 绥化市| 连平县|