Django-autocomplete-light 显示空下拉列表而不是自动完成小部件

2024-01-01

我正在尝试在我的项目中实现 django-autocomplete-light,但无法弄清楚为什么它不向我显示自动完成小部件,但一直显示空下拉列表。

我按照教程进行操作:https://django-autocomplete-light.readthedocs.io/en/3.1.3/tutorial.html https://django-autocomplete-light.readthedocs.io/en/3.1.3/tutorial.html.

我发现这个问题在其他 stackoverflow 问题中也出现过,但到目前为止这些答案都没有帮助我。

我有以下模型:

class Vilt(models.Model):
    vilt_title = models.CharField(max_length=200, unique=True)

我创建了这个自动完成视图:

class ViltAutocomplete(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 Vilt.objects.none()
        qs = Vilt.objects.all().order_by('vilt_title')

        if self.q:
            qs = qs.filter(vilt_title__istartswith=self.q)

        return qs

我使用这个 ModelForm 来指定小部件。

from .models import Vilt
from dal import autocomplete

class ViltSearchForm(forms.ModelForm):
  vilt_title = forms.ModelChoiceField(
    queryset = Vilt.objects.all(),
    widget = autocomplete.ModelSelect2(url='vilt-autocomplete')
  )

  class Meta:
    model = Vilt
    fields = ('vilt_title',)
from .views import (ViltAutocomplete,
                    )
urlpatterns = [
    #other paths
    path('vilt/autocomplete/', ViltAutocomplete.as_view(), name='vilt-autocomplete'),
    #other paths
]
{% extends "bierviltje/base.html" %}
{% load static %}
{% load crispy_forms_tags %}

{% block content %}
<div class="container">
#other forms
    <div>
        <form action="" method="post">
            {% csrf_token %}
            {{ vilt_search_form|crispy }}
            <input type="submit" />
        </form>
    </div>
#other forms
</div>
{% endblock content %}

{% block javascript %}
{{ vilt_search_form.media }}
{% endblock javascript %}

这是在 base.html 中的 javascript 块之前加载的 Javascript:

<!-- jQuery first, then Popper.js, then Bootstrap JS -->
<script src="https://code.jquery.com/jquery-3.2.1.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"></script>
{% block javascript %}
{% endblock javascript %}

自从您发布查询以来已经有一段时间了。但如果你还没有找到答案,这是解决方案:

在您的 ModelForm“ViltSearchForm”中,请更改小部件from:

widget = autocomplete.ModelSelect2(url='vilt-autocomplete')

to:

widget = autocomplete.ListSelect2(url='vilt-autocomplete')

但是,如果我可以在这里添加,我无法理解在独立模型.

如有反馈,我们将不胜感激。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Django-autocomplete-light 显示空下拉列表而不是自动完成小部件 的相关文章

随机推荐