我的项目是购物清单。我有两个模型:ShoppingList和ShoppingItem像这样:
models.py
class ShoppingItem (Model):
name = models.CharField(max_length=50, null=False)
count = models.IntegerField(null=False)
list = models.ForeignKey(ShoppingList, on_delete=models.CASCADE, related_name='shopping_items')
date_created = models.DateTimeField(auto_now_add=True)
urls.py
urlpatterns = [
path('ListDetails/<int:pk>', views.ListDetailUpdateView.as_view(), name='listdetailupdate'),
]
views.py
class ListDetailUpdateView(ListView):
model = ShoppingItem
template_name = 'xlist_app/ListDetailUpdateView.html'
context_object_name = 'products'
queryset = ShoppingItem.objects.filter(list = XXXX)
我需要返回url的一部分但在ListView(其中“ XXXX”)内部的函数
我的想法是削减url的最后一部分(例如,当我输入列表编号2时我具有地址http://127.0.0.1:8000/ListDetails/2
),并用这种功能替换“ XXXX”。
在我看来,它应该看起来像:
queryset = ShoppingItem.objects.filter(list = int(request.path.split('/')[-1])
如果有更好的方法,我将不胜感激。
类似的东西
class ListDetailUpdateView(ListView):
model = ShoppingItem
template_name = 'xlist_app/ListDetailUpdateView.html'
context_object_name = 'products'
def get_queryset(self):
return ShoppingItem.objects.filter(list=self.request.resolver_match.kwargs['pk'])
覆盖get_queryset
方法是一种方法。
调用super()
获取父方法返回的查询集。对其进行过滤应该可以正常工作。通过网址格式匹配的pk
将在self.kwargs
中可用。
class ListDetailUpdateView(ListView):
model = ShoppingItem
template_name = 'xlist_app/ListDetailUpdateView.html'
context_object_name = 'products'
def get_queryset(self):
qs = super(ListDetailUpdateView, self).get_queryset()
return qs.filter(list=self.kwargs.get('pk'))
我还考虑将list
字段名称更改为shopping_list
或类似名称,因为它遮盖了built-in list()
函数。