Evgenii Legotckoi
Evgenii Legotckoi26. März 2017 01:45

Django - Tutorial 021. Modellvererbung, abstraktes Modell

Nach dem Refactoring auf der Website wurden vier Hauptentitäten identifiziert, in denen gemeinsame Eigenschaften identifiziert wurden, nämlich:

  • Artikel - Artikel
  • Kommentar - Kommentare
  • ForumTopic - Forenthemen (auch bekannt als Fragen)
  • ForumPost - Antworten auf Forenthemen

Natürlich, und damit war klar, dass diese Entitäten die gleichen Datenfelder, die gleichen Methoden usw. haben können. Aber während ich diese Seite entwickle, lerne ich selbst gleichzeitig Python und Django. Daher hat das Projekt den Charakter einer chaotischen Einführung kleiner ToDos, gefolgt von Refactoring und dem Erlernen der besten Ansätze. Daher wurde nach Untersuchung der Möglichkeiten der Vererbung von Modellen in Django ein allgemeines abstraktes Datenmodell PostBase herausgegriffen, das vier Felder hat, die sich in allen oben genannten Modellen wiederholen.

Hier gibt es einen wichtigen Punkt: Ein als abstrakt deklariertes Modell erstellt keine Tabelle in der Datenbank.

Um ein abstraktes Modell zu erstellen, müssen Sie die Variable abstract für die Klasse Meta. auf True setzen


PostBase

PostBase - dies wird das abstrakte Basismodell sein. In diesem abstrakten Datenmodell wurden vier Felder identifiziert, die den obigen Modellen gemeinsam sind:

  • Autor - der Autor des Artikels, Kommentars, Themas oder der Antwort;
  • Inhalt - Inhalt;
  • pub_date - Datum der Veröffentlichung;
  • Moderation - Moderation, alle Inhalte können vier mögliche Optionen haben:
  • SPAM - keine Kommentare;
  • NOT_MODERATED - Unbestätigter Eintrag, in diesem Fall sind die Artikel von Benutzern mit diesem Status vor der Moderation für andere Benutzer nicht verfügbar;
  • POST_MODERATED - Moderation nach der Veröffentlichung, der Artikel des Benutzers wird nach der Veröffentlichung anderen Benutzern zur Verfügung stehen, aber er wurde noch nicht moderiert;
  • MODERIERT - Beitrag wurde moderiert.

Die Deklaration dieses abstrakten Modells lautet wie folgt:

# -*- coding: utf-8 -*-

from django.db import models
from django.contrib.auth.models import User
from django.utils.translation import ugettext_lazy as _

from ckeditor_uploader.fields import RichTextUploadingField

class PostBase(models.Model):
    class Meta:
        abstract = True    # данное поле указывает, что класс абстрактный
                           # и что для него не нужно создавать таблицу

    SPAM = 'S'
    NOT_MODERATED = 'N'
    POST_MODERATED = 'P'
    MODERATED = 'M'
    MODERATION_CHOICES = (
        (SPAM, 'SPAM'),
        (NOT_MODERATED, 'Not Moderated'),
        (POST_MODERATED, 'Post Moderated'),
        (MODERATED, 'Moderated')
    )

    author = models.ForeignKey(User, verbose_name=_("Автор"))
    content = models.TextField(_('Содержание'), blank=True)
    pub_date = models.DateTimeField(_('Дата публикации'), blank=True, null=True)
    moderation = models.CharField(
        _('Модерация'),
        max_length=1,
        choices=MODERATION_CHOICES,
        default=NOT_MODERATED
    )

Somit ist es möglich, den Programmcode des Projekts zu reduzieren und die Fähigkeit hinzuzufügen, sich wiederholenden Code wiederzuverwenden.

Der Aufbau des Modells beispielsweise für Kommentare kann nun so aussehen:

class Comment(PostBase):
    class Meta:
        db_table = "comments"

    article = models.ForeignKey(Article)

Die Felder author , pub_date , content und moderation müssen nicht mehr angegeben werden, da sie in der Klasse PostBase vorhanden sind. Am wichtigsten ist, dass Sie in Ihrem Modell keine gleichnamigen Felder wie im PostBase. -Modell eingeben.

PostBaseAdmin

Ein unbestrittener Vorteil ist auch, dass Sie eine Admin-Panel-Einstellung für alle Klassen gemeinsam vornehmen können.

Nehmen wir zum Beispiel die Anzeige von Feldern, die Einrichtung der Suche und Filterung von Inhalten und die Möglichkeit, den Moderationsstatus festzulegen (dh die entsprechenden Aktionen hinzuzufügen).

class PostBaseAdmin(admin.ModelAdmin):
    list_display = ('content', 'author', 'pub_date')
    search_fields = ('content', 'author__username')
    list_filter = ('moderation',)
    actions = ['make_spam', 'make_not_moderated', 'make_post_moderated', 'make_moderated']

    def moderate(self, request, rows_updated, choice_description):
        if rows_updated == 1:
            message_bit = "1 запись помечена, как %s" % choice_description
        else:
            message_bit = "%s записей отмечены, как %s." % (rows_updated, choice_description)
        self.message_user(request, "%s" % message_bit)

    def make_spam(self, request, queryset):
        self.moderate(
            request=request,
            rows_updated=queryset.update(moderation=PostBase.SPAM),
            choice_description="SPAM"
        )
    make_spam.short_description = "Отметить помеченные, как SPAM"

    def make_not_moderated(self, request, queryset):
        self.moderate(
            request=request,
            rows_updated=queryset.update(moderation=PostBase.NOT_MODERATED),
            choice_description="NOT_MODERATED"
        )
    make_not_moderated.short_description = "Отметить помеченные, как NOT_MODERATED"

    def make_post_moderated(self, request, queryset):
        self.moderate(
            request=request,
            rows_updated=queryset.update(moderation=PostBase.POST_MODERATED),
            choice_description="POST_MODERATED"
        )
    make_post_moderated.short_description = "Отметить помеченные, как POST_MODERATED"

    def make_moderated(self, request, queryset):
        self.moderate(
            request=request,
            rows_updated=queryset.update(moderation=PostBase.MODERATED),
            choice_description="MODERATED"
        )
    make_moderated.short_description = "Отметить помеченные, как MODERATED"

Wenn Sie die Filterlisten erweitern oder Aktionen für einige der Modelle hinzufügen möchten, können Sie wie folgt von PostBaseAdmin erben:

class ArticleAdmin(PostBaseAdmin):
    # Либо полностью переопределить отображаемые поля или поля для поиска
    list_display = ('title', 'section', 'author', 'pub_date', 'views', 'moderation')
    search_fields = ('title', 'author__username', 'section__title')
    # Либо добавить к существующему списку дополнительные
    list_filter = PostBaseAdmin.list_filter + ('status', 'section')
    # В случае actions подобное объявление просто добавит новые actions к существующим
    actions = ['publish', 'unpublish']

Für Django empfehle ich Timeweb-Hoster VDS-Server .

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
EVA
EVA25. Dezember 2023 10:30
Boost - statisches Verknüpfen im CMake-Projekt unter Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken