我有一个产品,类别和子类别的实体。类别可以包含许多产品,类别也可以包含许多子类别。例如,名为Iphone-4的产品可能属于电子产品和智能手机的智能手机子类别。小工具类别。 Similiary三星产品可以属于同类智能手机子类别的Electronics& Gadgets Category。我怎么能有效地展示这种关系?
这就是我做的事情
class Category(models.Model):
name = models.CharField(max_length=80, null=True)
parent = models.ForeignKey('self', blank=True, null=True, related_name="children")
class Meta:
unique_together = ('parent',)
verbose_name = 'Category'
verbose_name_plural = 'Categories'
class Product(models.Model):
token = models.CharField(default=token_generator, max_length=20, unique=True, editable=False)
category = models.ForeignKey(Category)
company = models.ForeignKey(Company, related_name="company_product")
name = models.CharField(max_length=200, null=True)
model = models.CharField(max_length=100, blank=True, null=True)
specification = models.TextField(null=True, blank=True)
price = models.PositiveIntegerField(default=0)
admin.py
class ProductAdmin(admin.ModelAdmin):
list_select_related = ('category', 'company',)
class Meta:
model = Product
class CategoryAdmin(admin.ModelAdmin):
list_select_related = ('parent',)
list_display = ('name', 'parent', )
class Meta:
model = Category
这种方式在我的管理员中,类别和子类别显示得很模糊。类别电子产品小工具多次显示。它显示为属于此类别的子类别数。 这是预期的行为还是必须处理这种其他有效方式?
答案 0 :(得分:0)
这是在管理面板中列出嵌套类别和子类别的代码片段。请先在您的应用的 admin.py 中注册 Category 模型。
# Category Model.
class Category(models.Model):
name = models.CharField(blank=False, max_length=200)
slug = models.SlugField(null=False)
parent = models.ForeignKey('self',blank=True, null=True ,related_name='children', on_delete=models.SET_NULL)
class Meta:
db_table = "dj_categories"
# Add verbose name
verbose_name = 'Category'
verbose_name_plural = "Categories"
unique_together = ('slug', 'parent',)
def __str__(self):
return self.name