Функция представления new_entry()
Функция представления new_entry очень похожа на функцию добавления новой темы:
views.py
from django.shortcuts import render
...
from .models import Topic
from .forms import TopicForm, EntryForm
...
def new_entry(request, topic_id):
. ."""Добавляет новую запись по конкретной теме."""
(1) . .topic = Topic.objects.get(id=topic_id)
. .
(2) . .if request.method != 'POST':
. . . .# Данные не отправлялись; создается пустая форма.
(3) . . . .form = EntryForm() . . . .
. .else:
. . . .# Отправлены данные POST; обработать данные.
(4) . . . .form = EntryForm(data=request.POST)
. . . .if form.is_valid():
(5) . . . . . .new_entry = form.save(commit=False)
? . . . . . .new_entry.topic = topic
. . . . . .new_entry.save()
? . . . . . .return HttpResponseRedirect(reverse('learning_logs:topic',
. . . . . . . . . . . . . . . . . . . .args=[topic_id]))
. .
. .context = {'topic': topic, 'form': form}
. .return render(request, 'learning_logs/new_entry.html', context)
Мы обновляем команду import и включаем в нее только что созданный класс EntryForm. Определение new_entry() содержит параметр topic_id для сохранения полученного значения из URL. Идентификатор темы понадобится для отображения страницы и обработки данных формы, поэтому мы используем topic_id для получения правильного объекта темы (1) .
В точке (2) проверяется метод запроса: POST или GET. Блок if выполняется для запроса GET, и мы создаем пустой экземпляр EntryForm (3). Для метода запроса POST мы обрабатываем данные, создавая экземпляр EntryForm, заполненный данными POST из объекта запроса (4). Затем проверяется корректность данных формы. Если данные корректны, необходимо задать атрибут topic объекта записи перед сохранением его в базе данных.
При вызове save() мы включаем аргумент commit=False (5) для того, чтобы создать новый объект записи и сохранить его в new_entry, не сохраняя пока в базе данных. Мы присваиваем атрибуту topic объекта new_entry тему, прочитанную из базы данных в начале функции ?, после чего вызываем save() без аргументов. В результате запись сохраняется в базе данных с правильной ассоциированной темой.
В точке ? пользователь перенаправляется на страницу темы. При вызове reverse() должны передаваться два аргумента: имя схемы URL, для которой генерируется URL-адрес, и список аргументов со всеми аргументами, которые должны быть включены в URL. Список аргументов содержит всего один элемент topic_id. Вызов HttpResponseRedirect() перенаправляет пользователя на страницу темы, для которой была создана запись, и пользователь видит новую запись в списке записей.