首页 > 解决方案 > 获取产品属性及其值

问题描述

产品和产品属性表的设计方式如下

class Attribute(models.Model):
    name = models.CharField(max_length=30, unique=True)
    slug = models.SlugField(max_length=250, unique=True)

    class Meta:
        verbose_name = "Attribute"
        verbose_name_plural = "Attributes"

    def __str__(self):
        return self.name


class AttributeValue(models.Model):
    name = models.CharField(max_length=250)
    value = models.CharField(max_length=100, blank=True, default="")
    slug = models.SlugField(max_length=255)
    attribute = models.ForeignKey(
        Attribute, related_name="values", on_delete=models.CASCADE
    )

    class Meta:
        ordering = ("sort_order", "id")
        unique_together = ("slug", "attribute")

    def __str__(self) -> str:
        return self.name

    def get_ordering_queryset(self):
        return self.attribute.values.all()


class ProductAttribute(models.Model):
    product = models.ForeignKey(Product, related_name="attribute_product", on_delete=models.CASCADE, null=True)
    attribute = models.ForeignKey(
        AttributeValue, related_name="attribute_value_product", on_delete=models.CASCADE
    )

    class Meta:
        ordering = ("sort_order",)
        verbose_name = "Product Attribute"
        verbose_name_plural = "Product Attributes"

    def __str__(self):
        return f'{self.product.name} - {self.attribute.name}'

    def get_ordering_queryset(self):
        return self.product.attribute_product.all()


class ProductTypeAttributeValue(models.Model):
    product_type = models.ForeignKey(ProductType, on_delete=models.CASCADE)
    attribute_value = models.ForeignKey(AttributeValue, on_delete=models.CASCADE)

    def __str__(self):
        return f'{self.product_type.name} - {self.attribute_value.value}'

我可以通过以下方式获取特定产品的属性列表

attribute = models.ProductAttribute.objects.filter(product=product)

我可以获得属性值和属性名称的值

for a in attribute:
   print(a.attribute.name, a.attribute.attribute.name)

这会给我

Small Size
Medium Size

但我不知道如何通过以下方式返回

attribute [
        {
        name: color,
        slug: color
        values [
            {
                id: 1,
                name: R,
                value: Red
            },
            {
                id: 2,
                name: G,
                value: Green
            }
        ]
    }
    ]

标签: pythondjangodjango-models

解决方案


class ProductAttribute(models.Model): product = models.ForeignKey( Product from where this Product model来自哪里?


推荐阅读