通过外键的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



