Evgenii Legotckoi
Evgenii Legotckoi22. November 2019 02:03

Django - Tutorial 050. Dynamische Site-Einstellungen mit SingletonModel erstellen

Angenommen, Sie erstellen eine Website mit einem Django-basierten CMS, das über eine Art dynamischer Website-Einstellungen verfügen muss, die dem Benutzer zur Verfügung stehen. Zum Beispiel der Name der Website, einige Fachinformationen, während Sie die Möglichkeit der Mehrsprachigkeit berücksichtigen. Was kann man dann dafür verwenden? Ich hatte eine Idee, eine Datenbank zu verwenden.

Zur Umsetzung wird Folgendes benötigt:

  1. Erstellen eines Datenmodells, das immer nur ein Objekt enthält, dh nur einen Datensatz. Das heißt, es wird ein Singleton-Modell sein.
  2. Verhindern Sie das Löschen dieses Eintrags und das Erstellen neuer Einträge im Django-Admin
  3. Die Möglichkeit, Informationen aus diesem Modell direkt in der Vorlage zu verwenden, ohne Site-Einstellungen in die Ansichtsfunktion zu laden.

Sehen wir uns an, wie Sie dies implementieren.


SingletonModel

Ich habe auf GitHub den Code für ein abstraktes SingletonModel gefunden, das 2012 geschrieben wurde. Hier ist Link zum Inhalt .

Hier ist der Code für dieses SingletonModel

class SingletonModel(models.Model):
    class Meta:
        abstract = True

    def save(self, *args, **kwargs):
        self.__class__.objects.exclude(id=self.id).delete()
        super(SingletonModel, self).save(*args, **kwargs)

    @classmethod
    def load(cls):
        try:
            return cls.objects.get()
        except cls.DoesNotExist:
            return cls()

Das Modell in der save -Methode speichert beim Speichern des Objekts automatisch alle anderen, wodurch Sie immer nur eine Instanz dieses Modells in der Datenbank speichern können.

Die load -Methode nimmt ein einzelnes Einstellungsobjekt aus der Datenbank, wenn es kein Objekt in der Datenbank gibt, gibt sie eine neue Instanz dieses Modells zurück, die dann gespeichert werden muss.

Lassen Sie uns unsere eigene Einstellungsklasse erstellen, die wir in Zukunft für unsere Anforderungen verwenden können.

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

from django.db import models
from django.utils.translation import ugettext_lazy as _

from my_app.singleton_model import SingletonModel


class SiteSettings(SingletonModel):
    site_url = models.URLField(verbose_name=_('Website url'), max_length=256)
    title = models.CharField(verbose_name=_('Title'), max_length=256)

    def __str__(self):
        return 'Configuration'

Einrichten des Admin-Panels

Jetzt müssen wir das Löschen dieses Eintrags und das Erstellen neuer Einträge im Django-Admin deaktivieren.

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

from django.contrib import admin
from django.db.utils import ProgrammingError

from my_app.models import SiteSettings


class SiteSettingsAdmin(admin.ModelAdmin):
    # Create a default object on the first page of SiteSettingsAdmin with a list of settings
    def __init__(self, model, admin_site):
        super().__init__(model, admin_site)
        # be sure to wrap the loading and saving SiteSettings in a try catch,
        # so that you can create database migrations
        try:
            SiteSettings.load().save()
        except ProgrammingError:
            pass

    # prohibit adding new settings
    def has_add_permission(self, request, obj=None):
        return False

    # as well as deleting existing
    def has_delete_permission(self, request, obj=None):
        return False


admin.site.register(SiteSettings, SiteSettingsAdmin)

Die Einstellungen können jetzt im Python-Code verwendet werden.

Erstellen Sie einen Kontextprozessor, um Einstellungen in eine Vorlage zu laden

context_processors.py

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

from evileg_settings.models import SiteSettings


def load_settings(request):
    return {'site_settings': SiteSettings.load()}

settings.py

Dann verbinden wir load_settings

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': [],
        'APP_DIRS': True,
        'OPTIONS': {
            'context_processors': [
                'django.template.context_processors.debug',
                'django.template.context_processors.request',
                'django.contrib.auth.context_processors.auth',
                'django.contrib.messages.context_processors.messages',
                # Загружаем наши настройки при каждом рендеринге шаблона с контекстом
                'my_app.context_processors.load_settings', 
            ],
        },
    },
]

Verwendung in Vorlage

<h1>{{ site_settings.title }}</h1>

Fazit

So können Sie schnell und einfach einfache dynamische Seiteneinstellungen in Django implementieren und diese dann an alle für uns interessanten Seitenparameter binden.
Der Vorteil dieses Ansatzes wird die Möglichkeit sein, Fremdschlüssel für einige spezielle Daten auf der Website zu verwenden, sowie die Verwendung von Django-Modellübersetzungen, was bedeutet, dass es keine Probleme mit Mehrsprachigkeit geben wird.

Рекомендуємо хостинг 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