#python #html #django #django-views
Вопрос:
Итак, я сделал проект Django в соответствии с учебником Django. И когда я набрал
python manage.py runserver
Это не то, что я хотел увидеть. Там должен быть список последних вопросов, потому что я ввожу его в индексный файл( я думаю, что проблема в представлениях или в html-файлах.
polls/views.py:
from django.http import HttpResponseRedirect
from django.template import loader
from django.shortcuts import get_object_or_404, render
from django.shortcuts import redirect
from django.shortcuts import render
from django.http import Http404
from django.views import generic
from django.utils import timezone
from . models import Answer, Question
class IndexView(generic.ListView):
template_name = 'polls/index.html'
context_object_name = 'latest_question_list'
def get_queryset(self):
return Question.objects.filter(
pub_date__lte=timezone.now()
).order_by('-pub_date')[:5]
class DetailView(generic.DetailView):
model = Question
template_name = 'polls/detail.html'
def get_queryset(self):
return Question.objects.filter(pub_date__lte=timezone.now())
class ResultsView(generic.DetailView):
model = Question
template_name = 'polls/results.html'
def vote(request, question_id):
question = get_object_or_404(Question, pk=question_id)
try:
selected_answer = question.answer_set.get(pk=request.POST['answer'])
except (KeyError, Answer.DoesNotExist):
# Redisplay the question voting form.
return render(request, 'polls/detail.html', {
'question': question,
'error_message': "You didn't select a answer.",
})
else:
selected_answer.votes = 1
selected_answer.save()
# Always return an HttpResponseRedirect after successfully dealing
# with POST data. This prevents data from being posted twice if a
# user hits the Back button.
return HttpResponseRedirect(reverse('polls:results', args=(question.id,)))
polls/index.html
{% load static %}
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Тест</title>
<link rel="stylesheet" type="text/css" href="{% static 'polls/main.css' %}" />
</head>
<body>
<h1>Доступные вопросы</h1>
{% if message %}
<p><strong>{{ message }}</strong></p>
{% endif %}
{% if latest_questions_list %}
<ul>
{% for question in latest_questions_list %}
<li>
<a href="{% url 'polls:detail' question.id %}}">{{ question.question_text }}
</a>
</li>
{% endfor %}
</ul>
{% else %}
<p>No questions are available right now.</p>
{% endif %}
</body>
</html>
Что я сделал не так?
Я новичок в django, так что не судите меня, пожалуйста 🙁
Комментарии:
1. Просто опечатка: вы установили
context_object_name = 'latest_question_list'
еще в своем шаблоне, который вы пишетеlatest_questions_list
(обратите внимание на дополнительноеs
).2. О, я даже не заметила. Я исправил это, спасибо!
Ответ №1:
Эта часть не ясна. Почему именно вы используете этот __lte
параметр для последних экземпляров вопросов. Я имею в виду, почему бы и нет Question.objects.order_by('-pub_date')[:5]
?
def get_queryset(self):
return Question.objects.filter(
pub_date__lte=timezone.now()
).order_by('-pub_date')[:5]
Комментарии:
1. Я думаю, что в ОП есть вопросы, которые можно задать для публикации в будущем, поэтому в этом представлении отображаются только опубликованные вопросы.
2. В учебнике было что-то о будущем времени вопросов, поэтому я использовал этот код вместо просто
Question.objects.order_by('-pub_date')[:5]
3. Итак, я написал
Question.objects.order_by('-pub_date')[:5]
и исправил ошибку с дополнительными «s», и код начал работать правильно. Большое вам спасибо, ребята!