通过外键的Django分面子类别

我有一个“顶级类别”和“中间类别”的项目列表,最终会有一个“低级类别”,但现在不是。例如,分别为电子>笔记本电脑。通过外键的Django分面子类别

我想动态方面对这一类,所以笔记本电脑将在电子等

我如何能达致这有什么想法显示?目前,我有'热门类别'正确面对。

models.py

class mid_category(models.Model): 

class Meta:

verbose_name_plural = 'Mid Categories'

name = models.CharField(max_length=500)

def __str__(self):

return self.name

class top_category(models.Model):

class Meta:

verbose_name_plural = 'Top Categories'

name = models.CharField(max_length=500)

mid_cat = models.ForeignKey(mid_category, null=True)

def __str__(self):

return self.name

# Item

class Product(models.Model):

title = models.CharField(max_length=500, db_index=True)

price = models.DecimalField(max_digits=10, decimal_places=2)

retailer = models.CharField(max_length=255)

image = models.CharField(max_length=1000)

url = models.URLField(max_length=800, unique=True, default='')

sku = models.BigIntegerField(default=0)

barcode = models.BigIntegerField(default=0)

featured = models.CharField(max_length=255, db_index=True, choices=FEATURED_CHOICES, default='NO')

timestamp = models.DateTimeField(auto_now=True)

top_cat = models.ForeignKey(top_category)

mid_cat = models.ForeignKey(mid_category, null=True)

def __str__(self):

return self.title

search_indexes.py

import datetime 

from django.utils import timezone

from haystack import indexes

from haystack.fields import CharField

from decimal import Decimal

from .models import Product, top_category

class ProductIndex(indexes.SearchIndex, indexes.Indexable):

text = indexes.EdgeNgramField(

document=True, use_template=True,

template_name='/home/wilkinj33/bargainforest/bargainforestenv/motorclass/templates/search/indexes/product_text.txt'

)

title = indexes.EdgeNgramField(model_attr='title')

retailer = indexes.CharField(model_attr='retailer', faceted=True)

price = indexes.IntegerField(model_attr='price', faceted=True)

barcode = indexes.CharField(model_attr='barcode')

topCat = indexes.CharField(model_attr='top_cat', faceted=True)

midCat = indexes.CharField(model_attr='mid_cat', faceted=True)

def get_model(self):

return Product

def index_queryset(self, using=None):

"""Used when the entire index for model is updated."""

return self.get_model().objects.filter(timestamp__lte=timezone.now())

results.html

  <h3 class="widget-title">Shop Categories</h3> 

<ul>

{% if facets.fields.topCat %}

{% for top_category in facets.fields.topCat %}

<li class="has-children"><a href="#" onclick="return onFacetChangeApplied();">{{top_category.0|cut:" "}}</a><span>(1138)</span>

<ul>

</ul>

</li>

{% endfor %}

{% endif %}

回答:

这似乎有点不可思议来构建你的模型这种方式。

在你当前的代码中,你似乎正在做这个错误的方法。顶级类别不是引用其父类的中间类别,而是顶级类别尝试引用其子级,这是不可能的,因为外键只能指向一个对象。

如果你想做到这一点在当前的代码,你需要这样的东西更是这样的:

class TopCategory(models.Model): 

name = ...

class MiddleCategory(models.Model):

name = ...

parent = models.ForeignKey(TopCategory)

更妙的是将更多的东西通用的,像这样的树结构,可以处理任何数量的水平类别:

`Product.objects.filter(category__parent=top_category) 

class Category(models.Model): 

name = ...

parent = models.ForeignKey('self', null=True, blank=True)

然后你就可以在父类像过滤器3210

,假设你有一个型号的FK到Category

更好的是,您应该使用类似django-mptt或django-treebeard的东西来提高树效率。

以上是 通过外键的Django分面子类别 的全部内容, 来源链接: utcz.com/qa/259449.html

回到顶部