Django 删除记录

删除记录

要删除记录,我们不需要新模板,但需要对 members 模板进行一些更改。

当然,您可以选择添加删除按钮的方式,但在本例中,我们将为新表列中的每条记录添加一个 "删除" 链接。

"删除" 链接还将包含每条记录的 ID。


修改模板

在 members 模板中添加一个 "删除" 列:

members/templates/index.html:

  1. <h1>Members</h1>
  2. <table border="1">
  3. {% for x in mymembers %}
  4. <tr>
  5. <td>{{ x.id }}</td>
  6. <td>{{ x.firstname }}</td>
  7. <td>{{ x.lastname }}</td>
  8. <td><a href="delete/{{ x.id }}">delete</a></td>
  9. </tr>
  10. {% endfor %}
  11. </table>
  12. <p>
  13. <a href="add/">Add member</a>
  14. </p>

结果如下:


URLs

HTML 表中的 “delete” 链接指向 127.0.0.1:8000/members/delete/ 因此我们将在 members/urls.py 文件中添加一个 path() 函数,将URL 指向正确的位置,ID 作为参数:

members/urls.py:

  1. from django.urls import path
  2. from . import views
  3. urlpatterns = [
  4. path('', views.index, name='index'),
  5. path('add/', views.add, name='add'),
  6. path('add/addrecord/', views.addrecord, name='addrecord'),
  7. path('delete/<int:id>', views.delete, name='delete'),
  8. ]

删除记录的代码

现在我们需要在 members/views.py 文件中添加一个名为 delete 的新视图:

members/views.py:

  1. from django.http import HttpResponse, HttpResponseRedirect
  2. from django.template import loader
  3. from django.urls import reverse
  4. from .models import Members
  5. def index(request):
  6. mymembers = Members.objects.all().values()
  7. template = loader.get_template('index.html')
  8. context = {
  9. 'mymembers': mymembers,
  10. }
  11. return HttpResponse(template.render(context, request))
  12. def add(request):
  13. template = loader.get_template('add.html')
  14. return HttpResponse(template.render({}, request))
  15. def addrecord(request):
  16. x = request.POST['first']
  17. y = request.POST['last']
  18. member = Members(firstname=x, lastname=y)
  19. member.save()
  20. return HttpResponseRedirect(reverse('index'))
  21. def delete(request, id):
  22. member = Members.objects.get(id=id)
  23. member.delete()
  24. return HttpResponseRedirect(reverse('index'))

删除视图执行以下操作:

  • 获取 id 作为参数。
  • 使用 id 在 Members 表中找到正确的记录。
  • 删除该记录。
  • 将用户重定向回索引视图。

点击 Jane Doe 的 "删除" 链接,查看结果: