我有办法定义内容列表项的顺序吗?
例如:
   ArticleContainer1 按此顺序包含:article1,article2,article3,article6
 ArticleContainer2 按此顺序包含:article3,article2,article1,article4
ArticleContainer3按此顺序包含:
 article5
这是我的课程:
class Article(models.Model):    
    title = models.CharField(max_length=200)
class ArticleContainer(models.Model):
   contents = models.ManyToManyField(Article, blank=True, null=True)
Fra*_*llo 26
所以这是我的一个例子,一个将人们组织成按部门排序的部门的网站.它与您的问题具有相同的概念,但具有不同的模型.此示例使用多对多通过表.
class Department(models.Model):
    slug = models.SlugField(
        verbose_name    = _(u'Slug'),
        help_text           = _(u'Uri identifier for this department.'),
        max_length=255
    )
    name = models.CharField(
        verbose_name    = _(u'Department Name'),
        help_text           = _(u'The department\'s name.'),
        max_length      = 255
    )
    description = models.TextField(
        verbose_name    = _(u'Description'),
        help_text           = _(u'Department\'s description')
    )
    people = models.ManyToManyField(
        Person,
        through             = 'DepartmentPeople',
        related_name    = 'people',
        verbose_name    = _(u'People'),
        help_text           = _(u'People in this Department')
    )
    order_by = models.IntegerField(
        verbose_name    = _(u'Ordering Weight'), 
        help_text           = _(u'This item\'s weight within a list.'),
        max_length      = 255
    )
    class Meta:
        verbose_name = _(u"Department")
        verbose_name_plural = _(u"Departments")
        ordering = ['order_by',]
    def people_list(self):
        return [dp.person for dp in DepartmentPeople.objects.filter(department=self).order_by('order')]
    def __unicode__(self):
        return self.name        
通过模型:
class DepartmentPeople(models.Model):
    person = models.ForeignKey(
        Person,
        verbose_name    = _(u'Person'),
        help_text           = _(u'Person is a member of this deparment.'),
    )
    department = models.ForeignKey(
        Department,
        verbose_name    = _(u'Department'),
        help_text           = _(u'Pseron is a member of this department.'),
    )       
    order = models.IntegerField(
        verbose_name    = _(u'Order'),
        help_text           = _(u'What order to display this person within the department.'),
        max_length      = 255
    )
    class Meta:
        verbose_name = _(u"Department Person")
        verbose_name_plural = _(u"Department People")
        ordering = ['order',]
    def __unicode__(self):
        return self.person.first_name + " " + self.person.last_name + " is a member of " + self.department.name + (" in position %d" % self.order)
和管理员:
class DepartmentPeopleInline(admin.TabularInline):
    model = DepartmentPeople
    extra = 1
class DepartmentAdmin(admin.ModelAdmin):
    inlines = (DepartmentPeopleInline,)
admin.site.register(Person, PersonAdmin)
admin.site.register(Department, DepartmentAdmin)
注意:以下是我的PersonAdmin,但是对于这个例子来说它是不必要的复杂.你可以通过一个简单的过程
class PersonAdmin(admin.ModelAdmin) :
    pass
但这是我在我的应用程序中使用的:
class PersonForm(forms.ModelForm):
    abstract = forms.CharField(
        widget=TinyMCE(attrs={'cols': 80, 'rows': 30})
    )
    class Meta:
        model = Person
class PersonAdmin(reversion.VersionAdmin):
    form = PersonForm
    # The Form Fieldsets
    fieldsets = [
        (
            None,
            {
                'fields'    : [('first_name', 'last_name', 'post_nominal', ), 'slug', 'title', 'headshot', 'large_photo', ('email', 'phone', ), 'abstract']
            },
        )
    ]
    # Prepopulated fields
    prepopulated_fields = {'slug': ('first_name', 'last_name', 'post_nominal', )}
    # Fields that are readonly
    #readonly_fields = ('slug', )
    def formfield_for_dbfield(self, db_field, **kwargs):
        if db_field.name == 'headshot':
            request = kwargs.pop("request", None)
            kwargs['widget'] = AdminImageWidget
            return db_field.formfield(**kwargs)
        return super(PersonAdmin, self).formfield_for_dbfield(db_field, **kwargs)
如果through为m2m关系使用明确定义的模型,则可以添加自己的属性order-id.然后,您可以扩展ManyToManyField以根据您在创建/更新时的逻辑填充order-id和模型m2m管理器,该管理器将在您通过order-id属性获取结果时对结果进行排序.
在 Django 2.0 上,Francis Yaconiello的公认答案运行良好,但由orderclass 字段的 max_length 参数引起的警告除外DepartmentPeople。
Django 忽略整数字段的 max_length,并会在 Django 1.8+ 中警告您。
我会在 Meta 子类中添加一个 unique_together 条目
class Meta:
    #...
    unique_together = ['person', 'department', 'order']
以防止数据输入错误。