【发布时间】:2010-12-06 20:29:13
【问题描述】:
我今天看到 Django 1.3 alpha 即将发布,最受吹捧的新功能是引入了class-based views。
我已经阅读了relevant documentation,但我发现我很难看到使用它们可以获得的巨大优势™,所以我在这里寻求一些帮助来理解它们。
让我们从文档中获取advanced example。
urls.py
>from books.views import PublisherBookListView
urlpatterns = patterns('',
(r'^books/(\w+)/$', PublisherBookListView.as_view()),
)
views.py
>from django.shortcuts import get_object_or_404
from django.views.generic import ListView
from books.models import Book, Publisher
class PublisherBookListView(ListView):
context_object_name = "book_list"
template_name = "books/books_by_publisher.html",
def get_queryset(self):
self.publisher = get_object_or_404(Publisher, name__iexact=self.args[0])
return Book.objects.filter(publisher=self.publisher)
def get_context_data(self, **kwargs):
# Call the base implementation first to get a context
context = super(PublisherBookListView, self).get_context_data(**kwargs)
# Add in the publisher
context['publisher'] = self.publisher
return context
现在让我们将其与我在 5 分钟内为这个问题制作的“普通旧视图”解决方案进行比较(对于您可能在其中发现的任何错误,我深表歉意)。
urls.py
>urlpatterns = patterns('books.views',
url(r'^books/(\w+)/$', 'publisher_books_list', name="publisher_books_list"),
)
views.py
>from django.shortcuts import get_object_or_404
from books.models import Book, Publisher
def publisher_books_list(request, publisher_name):
publisher = get_object_or_404(Publisher, name__iexact=publisher_name)
book_list = Book.objects.filter(publisher=publisher)
return render_to_response('books/books_by_publisher.html', {
"book_list": book_list,
"publisher": publisher,
}, context_instance=RequestContext(request))
第二个版本在我看来:
- 功能等效
- 可读性更强(
self.args[0]?糟透了!) - 更短
- 不低于 DRY 标准
我错过了什么重要的东西吗?我为什么要使用它们?那些在文档上吗?如果是这样,那么理想的用例是什么? mixins 有用吗?
提前感谢任何做出贡献的人!
P.S.对于那些可能想知道的人,我也从未被通用视图所吸引:只要我需要一些高级功能,它们就不会比普通视图短。
【问题讨论】:
-
是的,我也没有看到很大的优势。希望看到一个重要的答案。
-
完全同意。我对 self.args[0] 或 self.kwargs['slug'] 尤其反感。现在为 url 参数提供默认值也变得更加困难,例如:def publisher_books_list(request, publisher_name='Herbert')
标签: django django-class-based-views