今日、Django 1.3 alphaが出荷されていることを読みました。最も宣伝されている新機能は、クラスベースのビューの導入です。関連するドキュメント
を読みましたが、それらを使用することで得られる大きな利点™を見つけるのが難しいので、ここでそれらを理解するための助けを求めています。ドキュメントから高度な例を見て
みましょう。
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))
私にとって2番目のバージョンは次のように見えます。
- 機能的に同等
- もっと読みやすい(
self.args[0]
?ひどい!) - 短い
- DRY準拠以上
私が見逃している大きなものはありますか?なぜそれらを使用する必要がありますか?それらはドキュメントにありますか?もしそうなら、理想的なユースケースは何でしょうか?あるミックスイン便利なことは?
貢献してくれた人に感謝します!
不思議に思うかもしれない人のためのPS、私も一般的なビューに夢中になることはありませんでした:いくつかの高度な機能が必要になるとすぐに、それらは通常のビューよりも短くなりませんでした。