在xadmin组件中,当需要获取外键对应的对象时,我们可以通过remote_field得到QuerySet对象
from django.db.models.fields.related import ManyToManyField,ForeignKey
filter_field_obj = self.model._meta.get_field(filter_field) # app01.Book.authors
print(filter_field_obj)
if isinstance(filter_field_obj,ForeignKey) or isinstance(filter_field_obj,ManyToManyField):
data_list = filter_field_obj.remote_field.model.objects.all()
else:
data_list = self.config.model.objects.all().values(filter_field,"pk")
# <QuerySet [<Author: moke>, <Author: marks>]>
通过判断对象类型,可以区分普通字段与ForeignKey、多对多。
普通字段直接可以得到所有的数据,例如:
app01.Book.title
<QuerySet [{'title': 'java', 'pk': 4}, {'title': 'linux', 'pk': 5}, {'title': 'python', 'pk': 6}, {'title': 'java详解', 'pk': 8}]>
对于多对多,我们想要直接得到他的关联对象,可以通过ForeignKey内置方法。
在related.py下的类ForeignKey、ManyToManyField,均封装了rel该字典
kwargs['rel'] = self.rel_class(
self, to,
related_name=related_name,
related_query_name=related_query_name,
limit_choices_to=limit_choices_to,
symmetrical=symmetrical,
through=through,
through_fields=through_fields,
db_constraint=db_constraint,
)
之前django调用是:.rel.to.objects.all()
后来改动后,在初始化__init__中:
self.remote_field = rel
封装为一个类变量了,应该是方便调用。