Предоставляет механизм для поиска объекта, связанного с текущим запросом HTTP.
Методы и Атрибуты
Модель с которой “работает” данное представление(представление будет отображать данные этой модели). Указать model = Foo эквивалентно инструкции queryset = Foo.objects.all(), где objects является менеджером по умолчанию для модели Foo.
Запрос QuerySet, представляющий объекты. Если указан, то значение queryset замещает значение в model.
Предупреждение
queryset – атрибут класса с изменяемым значением, так что будьте осторожны при его использовании. Используя его, лучше вызывать метод all(), или получить его значение через метод get_queryset(), которые сделает копию атрибута.
Имя поля модели, содержащего слаг(slug). По умолчанию, slug_field это 'slug'.
Имя переданного ключевого аргумента(именованной группы) в URLConf, содержащего значение слага(slug). По умолчанию, slug_url_kwarg это 'slug'.
Имя переданного ключевого аргумента(именованной группы) в URLConf, содержащего значение первичного ключа(primary key). По умолчанию, pk_url_kwarg равен 'pk'.
Задает имя переменной для использования в текущем контексте.
При True метод get_object() ищет объект по первичному ключу и “слагу”. По умолчанию False.
Этот атрибут может помочь предотвратить атаку на незащищенный ресурс и прямой доступ к объектам. Если приложение предоставляет доступ к объектам через последовательный первичный ключ, атакующий может перебрать URL-ы и получить все объекты в приложении. Если пользователи не должны иметь доступ к списку всех объект, опция query_pk_and_slug позволит предотвратить подбор URL-ов через первичный ключ т.к. каждый URL будет требовать два правильных непоследовательных аргумента. Вы также можете просто использовать уникальный “slug” для этой цели, но эта опция позволит хранить не уникальный “slug”.
Возвращает объект, который отображается данным представлением. Если предоставлено значение queryset, то этот queryset будет использован для получения объекта; в противном случае будет использован результат вызова метода get_queryset(). Метод get_object() проверяет значение аргумента pk_url_kwarg, из списка переданных представлению; если этот аргумент найден, то метод выполнит поиск по первичному ключу(по переданному значению). Если этот аргумент не найден, то будет проверено наличие аргумента slug_url_kwarg, и выполнен поиск по значению слага(используя slug_field).
Если query_pk_and_slug равен True, get_object() будет искать объект по первичному ключу и значению “slug”.
Возвращает объект queryset, который буден использован для получения объекта для данного представления. По умолчанию, метод get_queryset() возвращает значение атрибута queryset (если он установлен), - в противном случае будет создан экземпляр класса QuerySet вызовом метода all() у атрибута :attr:`model`( с помощью менеджера по умолчанию).
Возвращает имя переменной контекста(context variable), которая будет доступна в шаблоне и будет содержать данные, с которыми работает представление. Если атрибут context_object_name не установлен, то имя переменной контекста будет составлено из model_name модели, “породившей” текущий queryset. Например, модель Article будет иметь переменную контекста с именем 'article'.
Возвращает данные контекста для отображения списка объектов.
Встроенная реализация этого метода требует чтобы атрибут object был установлен в представлении(пускай даже в None). Не забудьте об этом, когда будете использовать этот mixin без одного из встроенных представлений, которое уже делает это.
Возвращает имя поля, хранящего слаг(slug), которое будет использоваться при выборке данных по слагу. По умолчанию просто возвращает значение атрибута slug_field.
Контекст
object: объект, отображаемый данным представлением. Если указан атрибут context_object_name, то эта переменная будет также добавлена в контекст, с тем же значением, что и у object.
Класс-примесь, дающий возможность работы с шаблонами для представлений, отображающих одиночный объект. Требует, чтобы представление, в которое будет добавляться эта примесь, предоставляло значение self.object, - экземпляр объекта с которым “работает” представление. Обычно, хотя это и не требуется, self.object``это экземпляр модели Django. Это значение может быть ``None, если представление “в середине” процесса по созданию нового экземпляра объекта.
Наследуется от
Методы и Атрибуты
Поле на текущий экземпляр объекта, который может быть использован для определения имени шаблона кандидата(шаблона, который будет использован для отображения данных). Если либо само значение template_name_field или значение template_name_field в текущем экземпляре объекта равно None, то объект не будет использоваться для определения имени шаблона кандидата.
Суффикс, который добавляется к автоматически сгенерированным именам шаблонов кандидатов. Значение суффикса по умолчанию: _detail.
Возвращает список имен шаблонов кандидатов. Возвращает следующий список:
значение атрибута template_name в представлении(если указано)
содержимое поля template_name_field в экземпляре объекта, с которым работает представление(если доступно)
Jun 02, 2016