我有两个通过外键链接的 Django 模型:
class Author(models.Model):
...
class Book(models.Model):
author = models.ForeignKey(Author)
请考虑下面的管理员示例(我想做相反的事情):
from django.contrib import admin
from my_app.models import Author, Book
class BookInline(admin.TabularInline):
model = Book
class AuthorAdmin(admin.ModelAdmin):
inlines = [
BookInline,
]
admin.site.register(Author, AuthorAdmin)
在这个例子中,我们可以在管理员中看到所有作者,以及每个作者的书籍。
现在,我想反过来说。在管理中输入每本书,并在书籍详细信息中显示作者信息(可以是只读的)。我尝试了以下解决方案,但显然它没有用:
from django.contrib import admin
from my_app.models import Author, Book
class AuthorInline(admin.TabularInline):
model = Author
class BookAdmin(admin.ModelAdmin):
inlines = [
AuthorInline,
]
admin.site.register(Book, BookAdmin)
Django 引发错误:
<class 'my_app.admin.AuthorInline'>: (admin.E202) 'my_app.Author' has no ForeignKey to 'my_app.Book'.
你知道怎么做吗?
更多上下文:
- Django 1.11
- 我想将 Book 和 Author 显示为 full readonly,这样 Book 的外键就不会被改变(至少不会从 admin 改变)
最佳答案
这是我的解决方案,也许不是最好的,但它确实有效! :)
我的想法是更改模板,因此能够以我想要的方式显示它。
管理员.py :
class BookAdmin(admin.ModelAdmin):
...
change_form_template = 'admin/book_details.html'
def change_view(self, request, object_id, form_url='', extra_context=None):
extra_context = extra_context or {}
extra_context['book'] = Book.objects.get(id=object_id)
extra_context['author'] = extra_context['book'].author
return super().change_view(request, object_id, form_url, extra_context=extra_context)
admin.site.register(Book, BookAdmin)
对于模板,我只是复制/粘贴 template change_form.html from the admin .
admin/book_details.html:
{% extends "admin/base_site.html" %}
{% load i18n admin_urls static admin_modify %}
{% block extrastyle %}{{ block.super }}<link rel="stylesheet" type="text/css" href="{% static "admin/css/forms.css" %}" />{% endblock %}
{% block coltype %}colM{% endblock %}
{% block breadcrumbs %}
<div class="breadcrumbs">
<a href="{% url 'admin:index' %}">{% trans 'Home' %}</a>
› <a href="{% url 'admin:app_list' app_label=opts.app_label %}">{{ opts.app_config.verbose_name }}</a>
› {% if has_change_permission %}<a href="{% url opts|admin_urlname:'changelist' %}">{{ opts.verbose_name_plural|capfirst }}</a>{% else %}{{ opts.verbose_name_plural|capfirst }}{% endif %}
› {% if add %}{% blocktrans with name=opts.verbose_name %}Add {{ name }}{% endblocktrans %}{% else %}{{ original|truncatewords:"18" }}{% endif %}
</div>
{% endblock %}
{% block content %}
# Display here want you want !
{% endblock %}
我查看了 Django 管理员的模板,以便能够以与默认模板显示相同的方式显示我的书和作者。所以我的用户不会被这个 View 打扰。
如果您找到更好的方法,请告诉我! :)
关于python - 如何从具有外键角度的模型中显示 Django admin 中的相关对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44718355/