我正在使用管理界面查看发票和产品。为了方便起见,我将产品设置为发票内联,这样我就会在发票的表格中看到相关产品。如您所见,我使用的是多对多关系。
在 models.py 中:
class Product(models.Model):
name = models.TextField()
price = models.DecimalField(max_digits=10,decimal_places=2)
class Invoice(models.Model):
company = models.ForeignKey(Company)
customer = models.ForeignKey(Customer)
products = models.ManyToManyField(Product)
在 admin.py 中:
class ProductInline(admin.StackedInline):
model = Invoice.products.through
class InvoiceAdmin(admin.ModelAdmin):
inlines = [FilteredApartmentInline,]
admin.site.register(Product, ProductAdmin)
问题是 django 将产品显示为下拉菜单表(每个相关产品一个)。每个下拉菜单都包含列出的所有产品。因此,如果我有 5000 种产品,其中 300 种与某个发票相关联,django 实际上会加载 300x5000 个产品名称。 table 也不美观。
我不需要通过发票表格更新产品。我怎样才能改变它,以便它只显示在线表格中的产品名称? 我应该覆盖哪种形式,以及如何覆盖?
最佳答案
我觉得很简单,不要使用内联,只需要使用属性ModelAdmin.filter_horizontal
关于python - 如何在 django admin 中自定义多对多内联模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2893924/