Как Django узнает о том, что ему нужно изменить название поля title?

@admin.register(Post)
class PostAdmin(admin.ModelAdmin):
 list_display = ['title', 'slug', 'author', 'publish', 'status']
 list_filter = ['status', 'created', 'publish', 'author']
 search_fields = ['title', 'body']
 prepopulated_fields = {'slug': ('title',)}
 raw_id_fields = ['author']
 date_hierarchy = 'publish'
 ordering = ['status', 'publish']

Я знаю, что prepopulated_fields заполняет не только slufigy-поля. Как Django узнает, что поле slug должно быть заполнено слизью заголовка?

Джанго prepopulated_fields - это словарь, который сопоставляет имена полей с полями, которые он должен предварительно заполнить. Например:

class ArticleAdmin(admin.ModelAdmin):
    prepopulated_fields = {"slug": ["title"]}

Согласно docs:

При установке данного параметра поля будут заполняться из назначенных полей с помощью JavaScript. Основное применение этой функции - автоматическая генерация значения для полей SlugField из одного или нескольких других полей. Генерируемое значение создается путем конкатенации значений исходных полей, а затем путем преобразования этого результата в правильный slug (например, замена тире на пробелы и строчных ASCII-букв). Предварительно заполненные поля не изменяются JavaScript после сохранения значения. Обычно нежелательно, чтобы slug менялся (это может привести к изменению URL объекта, если в нем используется slug). prepopulated_fields не принимает поля DateTimeField, ForeignKey, OneToOneField и ManyToManyField.

Так что в вашем случае prepopulated_fields = {'slug': ('title',)} указывает Django заполнить slug заголовком исходного поля. Например, если у вас есть статья с заголовком "Моя первая статья", ваш url будет выглядеть следующим образом: "www.example.com/my-first-article", потому что slug дает вам человекочитаемый идентификатор для вашей веб-страницы. Это при условии, что вы используете slugs для своих урлов, а не id. На самом деле вы можете объединить оба варианта, чтобы получить что-то вроде этого "www.example.com/my-first-article/1", где 1 - это идентификатор статьи.

Вернуться на верх