首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Django:提交表单后,如何重定向到带有分页的ListView?

在Django中,要实现在提交表单后重定向到带有分页的ListView,可以按照以下步骤进行操作:

  1. 首先,在urls.py文件中定义一个URL模式,用于处理表单提交后的重定向。例如:
代码语言:txt
复制
from django.urls import path
from .views import MyListView, MyFormView

urlpatterns = [
    path('list/', MyListView.as_view(), name='my_list'),
    path('form/', MyFormView.as_view(), name='my_form'),
]
  1. 在views.py文件中,创建一个继承自ListView的视图类,用于显示带有分页的列表。例如:
代码语言:txt
复制
from django.views.generic import ListView
from .models import MyModel

class MyListView(ListView):
    model = MyModel
    paginate_by = 10
    template_name = 'my_list.html'
  1. 创建一个继承自FormView的视图类,用于处理表单提交。在该视图类中,重写form_valid()方法,以实现提交表单后的重定向。例如:
代码语言:txt
复制
from django.views.generic import FormView
from django.urls import reverse_lazy
from .forms import MyForm

class MyFormView(FormView):
    form_class = MyForm
    template_name = 'my_form.html'
    success_url = reverse_lazy('my_list')

    def form_valid(self, form):
        form.save()
        return super().form_valid(form)
  1. 在模板文件my_form.html中,编写表单的HTML代码。例如:
代码语言:txt
复制
<form method="post">
  {% csrf_token %}
  {{ form.as_p }}
  <button type="submit">提交</button>
</form>
  1. 在模板文件my_list.html中,编写显示列表的HTML代码。例如:
代码语言:txt
复制
{% for object in object_list %}
  <p>{{ object }}</p>
{% endfor %}

<div class="pagination">
  <span class="step-links">
    {% if page_obj.has_previous %}
      <a href="?page=1">&laquo; 第一页</a>
      <a href="?page={{ page_obj.previous_page_number }}">上一页</a>
    {% endif %}

    <span class="current-page">{{ page_obj.number }}</span>

    {% if page_obj.has_next %}
      <a href="?page={{ page_obj.next_page_number }}">下一页</a>
      <a href="?page={{ page_obj.paginator.num_pages }}">最后一页 &raquo;</a>
    {% endif %}
  </span>
</div>

通过以上步骤,当用户在表单页面提交表单后,会自动重定向到带有分页的列表页面,并显示提交的数据。同时,分页功能也会在列表页面中正常工作。

推荐的腾讯云相关产品:腾讯云服务器(CVM)、腾讯云数据库MySQL(TencentDB for MySQL)、腾讯云对象存储(COS)等。您可以通过访问腾讯云官方网站(https://cloud.tencent.com/)了解更多关于这些产品的详细信息。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

域名怎样实现自动跳转网页_域名

自动转向(Auto-Redirecting),也叫自动重定向。自动跳转,指当访问用户登陆到某网站时,自动将用户转向其它网页地址的一种技术。转向的网页地址可以是网站内的其它网页,也可以是其它网站。通常情况下,浏览器会收到一个网页,该页面含有自动加载一其它网页的代码。该页面有可能在服务器端被转换,这样的话,浏览器只收到一个页面,而自动转向往往意味着浏览器收到的页面具有自动将访问用户送至其它页面的功能。   对自动转向技术(Auto-Redirecting)的合理应用包括:将用户转向到指定浏览器的网页版本;当网站的域名变更或删除后将人们转向到新域名下,等等。但现在这种技术却往往被搜索引擎优化人士用来作为提高网站的搜索引擎排名的一种手段。例如,先专门针对搜索引擎做一个高度优化的网页,也就是我们通常所说的“桥页”,然后把这个网页提交给搜索引擎来获得好的排名。但是,当搜索用户通过搜索引擎的搜索结果列表点击该网页列表进入后,将被自动转向到一个用户本来无意去访问的网站地址。搜索引擎常常认为自动转向的网页是对读者的误导,所以它会对这种网页或网站施以惩戒,不过对一些自动转向方法它目前还无法自动检测出来。   Meta Refresh Tag自动转向法   由于搜索引擎能够读取HTML,而Meta tags也是HTML,所以对于这种自动转向法,搜索引擎能够自动检测出来。因而无论网站的转向出于什么目的,都很容易被搜索引擎视做对读者的误导而受到惩罚。不过,如果跳转延迟时间设置合适,搜索引擎就不会视之为作弊。   页面定时刷新元标识(Meta Refresh Tag)只能放在HTML代码的< HEAD>区里。如下所示:   <meta http-equiv=”refresh” content=”10;   其中的“10”是告诉浏览器在页面加载5秒钟后自动跳转到url这个页面。   这种方法常可以在论坛中见到。如果在论坛上发信息,先会看到一个确认页面,几秒后会自动重新跳转回当前的论坛页面中。   从搜索引擎优化的角度出发,一般不希望自动转向有延迟。不过,如果是用Meta Refresh标识进行转向,一定要注意把延迟时间设定成至少10秒以上。   “javascript”自动转向法   由于不能解析javascript,所以搜索引擎无法察觉(自动检测到)用javascript脚本进行的自动转向。javascript自动重定向脚本可以放在网页的任何位置上,如果要求立即跳转,则可以将其放入网页源码的<head>区内的最上面。用javascript实现跳转的范例如下:   <script language=”javascript”><!–location.replace(“pagename.html”)//–></script>   其中的“pagename.html”指特定的重定向目标地址,用相对/绝对URL地址均可。   用javascript实现自动重定向的好处在于:用户所访问的目标URL不会保留在用户浏览器的历史记录中,如果用户按返回按钮返回,则将回到跳转前的网页,而不是包含javascript自动重定向脚本的跳转页面,所以不会出现当用户点击返回按钮后返回至重定向页,然后该页自动跳转到用户本来想离开的那个页面的尴尬情形。   如果需要,可以把javascript自动重定向脚本存在一个外部文件中,并通过下面的命令行来加载,其中“filename.js”是该外部文件的路径和文件名:   <script language=”javascript” src=”filename.js”></script>   注意:若需实现即刻转向,或不希望人们看到转向前的那个页面,一般常用javascript脚本实现。在这种情况下应将javascript脚本放入HTML源码的<HEAD>区中。   表单(FORM)自动转向法   搜索引擎的“爬行”程序是不会填写表单的,所以它们也不会注意到提交表单,因而可以利用表单来实现自动转向(重定向)而不让搜索引擎察觉。   对于表单,人们往往很少意识到:表单的Action参数中包含的URL地址其实正是浏览器向服务器所请求的URL。浏览器将会通过向请求的URL地址增加一些格式为name=value的参数给予它以特殊的对待。在什么都没有的情况下,浏览器仍旧会为该URL安排请求至服务器。   用javascript脚本可让页面开始加载时即提交表单。下面是一个用javascript实现表单自动提交,以及提交表单的范例:   <script language=”javascript”><!–document.myform.submit()//–></script>   <form name=”myform” action=”pagename.html”

03
领券