8

在我的项目中,我将 django-mptt 用于类别。

我的模型:

class Category(models.model):
    name = models.CharField()
    parent = models.ForeignKey("self", blank=True, null=True,
                           related_name="sub_category")
    nav_order = models.IntegerField(null=False, blank=False, default=0)
    # unsure need nav_order column in DB

    class Meta:
        verbose_name_plural = 'Categories'
mptt.register(Category)

我需要有能力获得当前类别的订单,如下所示:

Category                Navigation order(one column)

CatA                      0
|-subcat11                 0
  |-sub11a                    0
  |-sub11b                    1
  \-sub11c                    2
\-subcat12                 1
CatB                      1  
|-subcat21                 0
|-subcat22                 1
\-subcat23                 2
  \-sub23a                    0
CatC                      2

如何在创建/移动元素时快速填写/重新计算订单列。或者通过 Category 的方法计算Category.objects.get(name='sub11b').get_order()应该返回 1。

4

2 回答 2

10

定义模型时,您可以使用“order_insertion_by”指定排序。

所以是这样的:

class Category(MPTTModel):
    name = models.CharField()
    parent = models.ForeignKey("self", blank=True, null=True, 
             related_name="sub_category")

    class MPTTMeta:
        order_insertion_by = ['name']

然后你可以重建你的数据库,Category.tree.rebuild()它应该尊重指定的顺序。

于 2012-02-03T12:11:48.617 回答
2

对于最新mptt版本(例如0.8.7),您应该使用以下TreeForeignKey字段:

from mptt.models import MPTTModel
from mptt.fields import TreeForeignkey

class Category(MPTTModel):
    name = models.CharField()
    parent = TreeForeignKey("self", 
                           blank=True, 
                           null=True, 
                           related_name="sub_category")

    class MPTTMeta:
        order_insertion_by = ['name']
于 2017-01-05T09:08:55.793 回答