gpt4 book ai didi

python - Tango with Django - 第 8 章 - 练习

转载 作者:搜寻专家 更新时间:2023-10-31 08:44:17 24 4
gpt4 key购买 nike

我需要一些帮助才能使 add_page 函数正常工作。我是 HTML 的新手,甚至是 Django 的新手。我正在处理的章节可以在这里找到:http://www.tangowithdjango.com/book17/chapters/forms.html .目前我的相关文件如下所示:

表格.py

from django import forms
from rango.models import Page, Category

class CategoryForm(forms.ModelForm):
name = forms.CharField(max_length=128, help_text="Please enter the category name.")
views = forms.IntegerField(widget=forms.HiddenInput(), initial=0)
likes = forms.IntegerField(widget=forms.HiddenInput(), initial=0)
slug = forms.CharField(widget=forms.HiddenInput(), required=False)

# An inline class to provide additional information on the form.
class Meta:
# Provide an association between the ModelForm and a model
model = Category
fields = ('name',)


class PageForm(forms.ModelForm):
title = forms.CharField(max_length=128, help_text="Please enter the title of the page.")
url = forms.URLField(max_length=200, help_text="Please enter the URL of the page.")
views = forms.IntegerField(widget=forms.HiddenInput(), initial=0)

class Meta:
# Provide an association between the ModelForm and a model
model = Page

# What fields do we want to include in our form?
# This way we don't need every field in the model present.
# Some fields may allow NULL values, so we may not want to include them...
# Here, we are hiding the foreign key.
# we can either exclude the category field from the form,
exclude = ('category',)
#or specify the fields to include (i.e. not include the category field)
#fields = ('title', 'url', 'views')

def clean(self):
cleaned_data = self.cleaned_data
url = cleaned_data.get('url')

# If url is not empty and doesn't start with 'http://', prepend 'http://'.
if url and not url.startswith('http://'):
url = 'http://' + url
cleaned_data['url'] = url

return cleaned_data

Views.py:

from django.shortcuts import render
from django.http import HttpResponse
from rango.models import Category, Page
from rango.forms import CategoryForm, PageForm

def index(request):
# Query the database for a list of ALL categories currently stored.
# Order the categories by no. likes in descending order.
# Retrieve the top 5 only - or all if less than 5.
# Place the list in our context_dict dictionary which will be passed to the template engine.
category_list = Category.objects.order_by('-likes')[:5]
page_list = Page.objects.order_by('-view')[:5]
context_dict = {'categories': category_list,
'pages': page_list}

# Render the response and send it back!
return render(request, 'rango/index.html', context_dict)

def category(request, category_name_slug):

# Create a context dictionary which we can pass to the template rendering engine.
context_dict = {}

try:
# Can we find a category name slug with the given name?
# If we can't, the .get() method raises a DoesNotExist exception.
# So the .get() method returns one model instance or raises an exception.
category = Category.objects.get(slug=category_name_slug)
context_dict['category_name'] = category.name
context_dict['category_name_slug'] = category_name_slug

# Retrieve all of the associated pages.
# Note that filter returns >= 1 model instance.
pages = Page.objects.filter(category=category)

# Adds our results list to the template context under name pages.
context_dict['pages'] = pages
# We also add the category object from the database to the context dictionary.
# We'll use this in the template to verify that the category exists.
context_dict['category'] = category
except Category.DoesNotExist:
# We get here if we didn't find the specified category.
# Don't do anything - the template displays the "no category" message for us.
pass

# Go render the response and return it to the client.
print context_dict
return render(request, 'rango/category.html', context_dict)

def add_category(request):
# A HTTP POST?
if request.method == 'POST':
form = CategoryForm(request.POST)

# Have we been provided with a valid form?
if form.is_valid():
# Save the new category to the database.
form.save(commit=True)

# Now call the index() view.
# The user will be shown the homepage.
return index(request)
else:
# The supplied form contained errors - just print them to the terminal.
print form.errors
else:
# If the request was not a POST, display the form to enter details.
form = CategoryForm()

# Bad form (or form details), no form supplied...
# Render the form with error messages (if any).
return render(request, 'rango/add_category.html', {'form': form})

def add_page(request, category_name_slug):

try:
cat = Category.objects.get(slug=category_name_slug)
except Category.DoesNotExist:
cat = None

if request.method == 'POST':
form = PageForm(request.POST)
if form.is_valid():
if cat:
page = form.save(commit=False)
page.category = cat
page.views = 0
page.save()
# probably better to use a redirect here.
return category(request, category_name_slug)
else:
print form.errors
else:
form = PageForm()

context_dict = {'form':form, 'category': cat}

return render(request, 'rango/add_page.html', context_dict)

网址.py

from django.conf.urls import patterns, url
from rango import views

urlpatterns = patterns('',
url(r'^$', views.index, name='index'),
# url(r'^about/$', views.about, name='about'),
url(r'^add_category/$', views.add_category, name='add_category'),
url(r'^category/(?P<category_name_slug>[\w\-]+)/add_page/$', views.add_page, name='add_page'),
url(r'^category/(?P<category_name_slug>[\w\-]+)/$', views.category, name='category'),)

我认为这 ^ 是我遇到问题的地方。我设法进入“添加页面”屏幕,但是当我尝试提交内容时,我收到一条错误消息,指出我只提供 1 个参数,而 add_page() 需要 2 个参数。我想我可能需要一个额外的 url,即类似于“add_category” URL,但其他 URL 一定意味着指向错误的地方吗?

类别.html

<!DOCTYPE html>
<html>
<head>
<title>Rango</title>
</head>

<body>
<h1>{{ category_name }}</h1>
{% if category %}
{% if pages %}
<ul>
{% for page in pages %}
<li><a href="{{ page.url }}">{{ page.title }}</a></li>
{% endfor %}
</ul>

{% else %}
<strong>No pages currently in category.</strong>
{% endif %}
<li><a href="/rango/category/{{ category_name_slug }}/add_page/">Add a New Page</a></li>
{% else %}
The specified category {{ category_name }} does not exist!
{% endif %}
</body>
</html>

add_page.html:

<!DOCTYPE html>
<html>
<head>
<title>Rango</title>
</head>

<body>
<h1>Add a Page</h1>

<form id="page_form" method="post" action="/rango/add_page/">

{% csrf_token %}
{% for hidden in form.hidden_fields %}
{{ hidden }}
{% endfor %}

{% for field in form.visible_fields %}
{{ field.errors }}
{{ field.help_text }}
{{ field }}
{% endfor %}

<input type="submit" name="submit" value="Create Page" />
</form>
</body>

</html>

最佳答案

我编辑了 add_page 函数以包含 category_name_slug:

def add_page(request, category_name_slug):

try:
cat = Category.objects.get(slug=category_name_slug)
except Category.DoesNotExist:
cat = None

if request.method == 'POST':
form = PageForm(request.POST)
if form.is_valid():
if cat:
page = form.save(commit=False)
page.category = cat
page.views = 0
page.save()
# probably better to use a redirect here.
return category(request, category_name_slug)
else:
print form.errors
else:
form = PageForm()

# made the change here
context_dict = {'form':form, 'category': cat, 'category_name_slug': category_name_slug}

return render(request, 'rango/add_page.html', context_dict)

然后我将 add_page.html 编辑为如下所示:

<!DOCTYPE html>
<html>
<head>
<title>Rango</title>
</head>

<body>
<h1>Add a Page</h1>

<form id="page_form" method="post" action="/rango/category/{{ category_name_slug }}/add_page/">

{% csrf_token %}
{% for hidden in form.hidden_fields %}
{{ hidden }}
{% endfor %}

{% for field in form.visible_fields %}
{{ field.errors }}
{{ field.help_text }}
{{ field }}
{% endfor %}

<input type="submit" name="submit" value="Create Page" />
</form>
</body>

</html>

关于python - Tango with Django - 第 8 章 - 练习,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28372435/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com