我希望以相同的形式显示两个按钮,我想用于删除对象的第一个按钮,以及用于创建对象的第二个按钮。
例如,我想创建简单的模型,如:
models.py:
class UrlStatus_Proxy(models.Model):
urls = models.URLField(u'Site URL', max_length=100, null=True, unique=True)
status_url = models.CharField(u'Site', max_length=20, choices=STATUS_URL)
urls.py
url(r'^url_status/$',ProxyUrlCreateView.as_view(model=UrlStatus_Proxy,
get_success_url=lambda: reverse('proxy_url_status'),template_name='proxy_url_status.html'), name='proxy_url_status'),
proxy_url_status.html
<form action="" method="post">
{{form.as_p}}
<input type="submit" name="delete" id="delete">
<input type="submit" name="add" id="add">
</form>
如果我在数据库中没有对象,那么什么也不做,只是从Model中显示表单,并且你只有一个选项可以在数据库中添加新对象。
如果我在数据库中有对象,那么列表对象如表和表中我有一个复选框字段。当我选中其中一个对象并单击“删除”按钮时,我想删除该对象。
在第二种情况下如果我从对象填充输入字段并按下“添加”按钮,我想在基础中添加对象。
我该怎么办?
答案 0 :(得分:3)
首先将所有现有对象添加到CreateView的上下文中,然后更新HTML模板以将这些对象呈现为表单上方的表格。然后创建一个DeleteView并将URL映射到它。
url(r"^url_status/$",
ProxyUrlCreateView.as_view(),
name="proxy_url_status"),
url(r"^url_status/(?P<pk>\d+)/delete/?$",
DeleteProxyURLView.as_view(),
name="delete_proxy"),
from django.views.generic import DeleteView
from django.core.urlresolvers import reverse
# add existing objects to the context, making them available to the template
class ProxyUrlCreateView(CreateView):
model = UrlStatus_Proxy
template_name = "proxy_url_status.html"
def get_success_url(self):
return reverse("proxy_url_status")
def get_context_data(self, **kwargs):
kwargs["object_list"] = UrlStatus_Proxy.objects.all()
return super(ProxyUrlCreateView, self).get_context_data(**kwargs)
class DeleteProxyURLView(DeleteView):
model = UrlStatus_Proxy
def get_success_url(self):
"""
Redirect to the page listing all of the proxy urls
"""
return reverse("proxy_url_status")
def get(self, *args, **kwargs):
"""
This has been overriden because by default
DeleteView doesn't work with GET requests
"""
return self.delete(*args, **kwargs)
<table>
{% for proxy_url in object_list %}
<tr>
<td>{{ proxy_url.urls }}</td>
<td><a href="{% url delete_proxy %}">Delete</a></td>
</tr>
{% endfor %}
</table>
<form action="" method="post">
{{form.as_p}}
<input type="submit" name="add" id="add">
</form>