时间:2021-05-22
开发环境:
场景一
经常有从数据库中获取一批数据,然后在前端以列表的形式展现,比如:获取到所有的用户,然后在用户列表页面展示。
解决方案
常规写法是,我们通过Django的ORM查询到所有的数据,然后展示出来,代码如下:
def user_list(request): """返回UserProfile中所有的用户""" users = UserProfile.objects.all() return render(request, 'talks/users_list.html', context={"user_list": users})这样能够解决问题,但是Django针对这种常用场景,提供了一个更快速便捷的方式,那就是ListView,用法如下:
from django.views.generic import ListViewclass UsersView(ListView): model = UserProfile template_name = 'talks/users_list.html' context_object_name = 'user_list'这样我们就完成了上边功能,代码很简洁。
场景二:
我想要对数据做过滤,ListView怎么实现?代码如下:
from django.views.generic import ListViewclass UsersView(ListView): model = UserProfile template_name = 'talks/users_list.html' context_object_name = 'user_list' def get_queryset(self): # 重写get_queryset方法 # 获取所有is_deleted为False的用户,并且以时间倒序返回数据 return UserProfile.objects.filter(is_deleted=False).order_by('-create_time')如果你要对数据做更多维度的过滤,比如:既要用户是某部门的,还只要获取到性别是男的,这时候,可以使用Django提供的Q函数来实现。
场景三
我想要返回给Template的数据需要多个,不仅仅是user_list,可能还有其他数据,如获取当前登陆用户的详细信息,这时怎么操作?,代码如下:
from django.views.generic import ListViewclass UsersView(ListView): model = UserProfile template_name = 'talks/users_list.html' context_object_name = 'user_list' def get_context_data(self, **kwargs): # 重写get_context_data方法 # 很关键,必须把原方法的结果拿到 context = super().get_context_data(**kwargs) username = self.request.GET.get('user', None) context['user'] = UserProfile.objects.get(username=username return context这样,你返回给Template页面时,context包含为{'user_list': user_list, 'user': user}。
场景四
我想要限制接口的请求方式,比如限制只能GET访问,代码如下:
from django.views.generic import ListViewclass UsersView(ListView): model = UserProfile template_name = 'talks/users_list.html' context_object_name = 'user_list' http_method_names = ['GET'] # 加上这一行,告知允许那种请求方式场景五
我卡卡卡的返回了所有的数据给前端页面,前页面最好得分页展示呀,这怎么搞?
到此这篇关于Django的ListView超详细用法(含分页paginate)的文章就介绍到这了,更多相关Django的ListView用法内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
参数paginate(每页数量,是否简洁分页,分页参数)使用方式$list=db('user')->paginate(10);自定义参数传参$list=db('
分页类,我放在plugin/Paginate.js复制代码代码如下:/***分页插件类(缺少每页的显示数,listrows明天写)*@parampage{Num
统计关联数量,单个用法$posts=Post::withCount('comments')->orderBy('id','desc')->paginate(6)
listview列表实现分页是非常容易的。ListView分页是非常简单的,加上一个DataPager控件,把ListView的ID赋予就可以了。最开始我就是这
Ubuntu系统如何创建Django超极用户?今天我们就来讲讲在Ubuntu里创建Django超极用户的方法,请看下文详细图文介绍。在Ubuntu里创建Djan