现在让我们来仔细看看这个 queryset 。 大多数通用视图有一个queryset参数,这个参数告诉视图要显示对象的集合。
举一个简单的例子,我们打算对书籍列表按出版日期排序,最近的排在最前:
book_info = { 'queryset': Book.objects.order_by('-publication_date'),} urlpatterns = patterns('',(r'^publishers/$',list_detail.object_list,publisher_info),**(r'^books/$',book_info),** )
这是一个相当简单的例子,但是很说明问题。 当然,你通常还想做比重新排序更多的事。 如果你想要呈现某个特定出版商出版的所有书籍列表,你可以使用同样的技术:
**apress_books = {** **'queryset': Book.objects.filter(publisher__name='Apress Publishing'),** **'template_name': 'books/apress_list.html'** **}** urlpatterns = patterns('',**(r'^books/apress/$',apress_books),** )
注意 在使用一个过滤的 queryset 的同时,我们还使用了一个自定义的模板名称。 如果我们不这么做,通用视图就会用以前的模板,这可能不是我们想要的结果。
同样要注意的是这并不是一个处理出版商相关书籍的最好方法。 如果我们想要添加另一个 出版商页面,我们就得在URL配置中写URL配置,如果有很多的出版商,这个方法就不能 接受了。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。