django实战(二)--带多字段模糊查询的分页(也是不容易)
上节我们实现了分页功能,这节我们要实现对模糊查询后的结果进行分页。(引入了bootstrap框架) urls.py from django.urls import path . import views app_name='person' urlpatterns=[ path(curd/,views.curd_index),path(curd/<int:pn>',views.curd_index,name="curdindex"),] models.py class Publisher(models.Model): id = models.AutoField(primary_key=True) name = models.CharField(max_length=64,null=False,unique=True) def __str__(self): # return "publisher_name:{}".format(self.name) return {}.format(self.name) Book(models.Model): id = models.AutoField(primary_key=True) title = models.CharField(max_length=128,null=False) introduce=models.TextField(max_length=120) publisher = models.ForeignKey(to=PublisherNone) book_title:{}.format(self.title) Meta: ordering=[id'] 你说我对单个表不就好了,为啥还要搞个外键出来!!! views.py from django.db.models import Q from django.shortcuts render from .models Book from django.core.paginator Paginator,EmptyPage def curd_index(request,pn=1): 获取前端收到的查询的值,默认值为空 query=request.GET.get(query) 如果存在,则对title和publisher进行模糊查询 if query: book_obj = Book.objects.all().filter(Q(title__contains=query)|Q(publisher__name__contains=query)) 否则取得所有的记录,并设置query的初始值为'' else: 启动服务器后: ? ? ?我们点击下一页: ? ? ?注意到浏览器中地址变成了http://127.0.0.1:8000/curd/2?query=,接下来,我们尝试输入“p” ? 我们按title进行了模糊查询,但是浏览器地址为:http://127.0.0.1:8000/curd/3?query=p&submit=%E6%8F%90%E4%BA%A4。我们查询后的/curd/3这里不应该是1么,从第一页开始?这就是我们之前进行异常控制的原因。如果我们不设置,就会报错Emptypage,因为不是从第三页开始的。我们尝试下一页,浏览器地址:http://127.0.0.1:8000/curd/2?query=p,这正如我们所说,跳转到第二页了,同时,我们仍然位于模糊查询的列表中。因为我们在第一次进行模糊查询时,后端将从前端获得的query重新传回给了前端,并保存在url路径中,所以我们选择页面的时候,只是会改变页面的值,而后面的query仍然是存在的。 我们再输入"广州": ? ?同样得到了按publisher选择的结果,这是因为我们在模糊查询中进行了选择。 补充:每记录一篇,都要参考不少别人的东西,由于django的多样性,别人写的不可能完全适合自己,这就需要自己从中提取对自己有益的东西。 技术总结:写完分页后,想到应该如何根据模糊查询后的结果进行分页呢?其实就是一个传参,接受参数的过程。其中遇到的另一个坑就是,自己非要利用外键进行关联查询,在进行模糊查询时,publisher是外键,不能直接用publisher__contains,而应该用publisher__name__contains,否则会报错:FieldError。 还是一句话:每学一点东西,就越发感觉还有好多东西可以学,啊啊啊。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |