如何在管理中使用 Django-autocomplete-light 作为外键
How to use Django-autocomplete-light for foreign key in the admin
我一直在努力向 django admin fk 字段添加自动完成功能,我遇到了这个第三方应用程序 Django-autocomplete-light,但它的文档对于像我这样的初学者来说非常混乱。
所以,我有我的模型,我如何为 fk 字段添加自动完成。
Class Order(models.Models)
Client = models.ForeignKey(settings.AUTH_USER_MODEL)
你应该看看 documentation 并尝试慢慢阅读。如果您提供更多详细信息,说明哪些不适合您,也许我们可以提供更好的帮助。一般来说,这是需要的:
在你的views.py文件中添加
from django.contrib.auth.models import User
from dal import autocomplete
from your_countries_app.models import Country
class ClientAutocomplete(autocomplete.Select2QuerySetView):
def get_queryset(self):
# Don't forget to filter out results depending on the visitor !
if not self.request.user.is_authenticated():
return User.objects.none()
qs = User.objects.all()
if self.q:
qs = qs.filter(name__istartswith=self.q)
return qs
然后在您的 urls.py 文件中添加:
from your_countries_app.views import ClientAutocomplete
urlpatterns = [
url(
r'^client-autocomplete/$',
ClientAutocomplete.as_view(),
name='client-autocomplete',
),
]
让我们跳过文档中带有 shell 的部分,如果它让您感到困惑的话。所以现在你应该可以从浏览器访问这个地址了。
localhost:8000/client-autocomplete/
你应该可以在那里看到所有用户的文本格式(这种格式叫做JSON,如果你愿意,你可以查一下,但我们不会处理它)。
如果您为订单创建了另一个应用程序,并且正在另一个文件夹中工作,只需尝试以订单作为前缀调用 url:
localhost:8000/orders/client-autocomplete/
我想你熟悉 Django 中的表单,如果不熟悉的话 take a look here. 在你的 forms.py 中添加:
from dal import autocomplete
from django.contrib.auth.models import
from django import forms
class OrderForm(forms.ModelForm):
client = forms.ModelChoiceField(
queryset=User.objects.all(),
widget=autocomplete.ModelSelect2(url='cllient-autocomplete')
# if you are working in an orders application, and you have defined the the url
#in the orders/urls.py then call this method like this:
#widget=autocomplete.ModelSelect2(url='orders:cllient-autocomplete')
)
class Meta:
model = Order
fields = ('__all__')
我想您希望自动完成功能在管理面板视图之外工作,因此您必须在订单视图的模板中添加以下代码。请注意,您应该在 base.html 中定义 {% block content %} 和 {% block footer %}:
{% extends 'base.html' %}
{# Don't forget that one ! #}
{% load static %}
{% block content %}
<div>
<form action="" method="post">
{% csrf_token %}
{{ form.as_p }}
<input type="submit" />
</form>
</div>
{% endblock %}
{% block footer %}
<script type="text/javascript" src="{% static 'admin/js/vendor/jquery/jquery.js' %}"></script>
{{ form.media }}
{% endblock %}
我一直在努力向 django admin fk 字段添加自动完成功能,我遇到了这个第三方应用程序 Django-autocomplete-light,但它的文档对于像我这样的初学者来说非常混乱。
所以,我有我的模型,我如何为 fk 字段添加自动完成。
Class Order(models.Models)
Client = models.ForeignKey(settings.AUTH_USER_MODEL)
你应该看看 documentation 并尝试慢慢阅读。如果您提供更多详细信息,说明哪些不适合您,也许我们可以提供更好的帮助。一般来说,这是需要的:
在你的views.py文件中添加
from django.contrib.auth.models import User
from dal import autocomplete
from your_countries_app.models import Country
class ClientAutocomplete(autocomplete.Select2QuerySetView):
def get_queryset(self):
# Don't forget to filter out results depending on the visitor !
if not self.request.user.is_authenticated():
return User.objects.none()
qs = User.objects.all()
if self.q:
qs = qs.filter(name__istartswith=self.q)
return qs
然后在您的 urls.py 文件中添加:
from your_countries_app.views import ClientAutocomplete
urlpatterns = [
url(
r'^client-autocomplete/$',
ClientAutocomplete.as_view(),
name='client-autocomplete',
),
]
让我们跳过文档中带有 shell 的部分,如果它让您感到困惑的话。所以现在你应该可以从浏览器访问这个地址了。
localhost:8000/client-autocomplete/
你应该可以在那里看到所有用户的文本格式(这种格式叫做JSON,如果你愿意,你可以查一下,但我们不会处理它)。 如果您为订单创建了另一个应用程序,并且正在另一个文件夹中工作,只需尝试以订单作为前缀调用 url:
localhost:8000/orders/client-autocomplete/
我想你熟悉 Django 中的表单,如果不熟悉的话 take a look here. 在你的 forms.py 中添加:
from dal import autocomplete
from django.contrib.auth.models import
from django import forms
class OrderForm(forms.ModelForm):
client = forms.ModelChoiceField(
queryset=User.objects.all(),
widget=autocomplete.ModelSelect2(url='cllient-autocomplete')
# if you are working in an orders application, and you have defined the the url
#in the orders/urls.py then call this method like this:
#widget=autocomplete.ModelSelect2(url='orders:cllient-autocomplete')
)
class Meta:
model = Order
fields = ('__all__')
我想您希望自动完成功能在管理面板视图之外工作,因此您必须在订单视图的模板中添加以下代码。请注意,您应该在 base.html 中定义 {% block content %} 和 {% block footer %}:
{% extends 'base.html' %}
{# Don't forget that one ! #}
{% load static %}
{% block content %}
<div>
<form action="" method="post">
{% csrf_token %}
{{ form.as_p }}
<input type="submit" />
</form>
</div>
{% endblock %}
{% block footer %}
<script type="text/javascript" src="{% static 'admin/js/vendor/jquery/jquery.js' %}"></script>
{{ form.media }}
{% endblock %}