1

我正在尝试了解 Django 的基于类的视图(对它来说非常新),尤其是 ListView。我正在努力理解“业务逻辑应该去哪里”。例如,我有以下课程:

#views.py
class DisplayListView(ListView):
    model = Cars
    template_name = "searchres_list.html"
    paginate_by = '5'
    context_object_name = "titles"

def get_context_data(self, **kwargs):
    context = super(SearchDisplayListView, self).get_context_data(**kwargs)
            # custom logic whoch spits out "now". in this example [1 -->10]
    context['now'] = [1,2,3,4,5,6,7,8,9,10]
    return context

它工作正常,我可以在我的模板上查看 [1 --> 10]。但是,当我查看ListView下可用的方法时,我发现我可能会将我的逻辑包含在 get_queryset 方法中。所以,像:

def get_queryset(self):
    # Fetch the queryset from the parent get_queryset
    queryset = super(SearchDisplayListView, self).get_queryset()
             # custom logic whoch spits out "now". in this example [1 -->10]
    queryset = [1,2,3,4,5,6,7,8,9,10]
            return queryset

所以,我相当(愚蠢)的问题是(或者我完全错了!),理想情况下业务逻辑应该去哪里:

  1. def get_context_data
  2. def get_queryset

谢谢你的时间。

4

1 回答 1

3

对于这样一个主观问题,最好的答案可能是:视情况而定。

我处理这种情况的个人算法如下:

  • 如果您需要向将传递给模板的上下文添加一些内容,那么您实际上别无选择,因为在get_queryset方法中您只能修改 ListView 的查询集。所以我在这种情况下使用 get_context_data 。
  • 但是如果您要执行一些动态查询集修改,假设您的视图可以在类似的模型类上运行,并且实际的类由传递给视图的参数确定,那么您可能需要覆盖get_queryset方法。

希望我能给你一些关于这个话题的见解:)

于 2013-02-14T21:45:10.190 回答