Django 自动完成灯:未填充字段

Posted

技术标签:

【中文标题】Django 自动完成灯:未填充字段【英文标题】:Django autocomplete light: field not populated 【发布时间】:2016-07-02 03:18:25 【问题描述】:

我已经安装了“Django autocomplete light”,现在正在学习本教程:https://django-autocomplete-light.readthedocs.org/en/master/tutorial.html

到目前为止,这是我的代码:

setting.py

INSTALLED_APPS = (
'dal',
'dal_select2',
'garages',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
)

models.py

class Country(models.Model):
    name = models.CharField(max_length=200)

    def __str__(self):
        return self.name


class Person(models.Model):
    birth_country = models.ForeignKey(Country)

    def __str__(self):
        return self.birth_country

views.py

class CountryAutocomplete(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 Country.objects.none()
        qs = Country.objects.all()
        if self.q:
            qs = qs.filter(name__istartswith=self.q)
        return qs


def create_person(request):
    person_form = PersonForm()
    c = 
        'person_form': person_form,
    
    c.update(csrf(request))

    return render_to_response('garages/person_form.html', c,
                              context_instance=RequestContext(request))

forms.py

class PersonForm(forms.ModelForm):
class Meta:
    model = Person
    fields = '__all__'
    widgets = 
        'birth_country': autocomplete.ModelSelect2(url='garages:country-autocomplete')
    

urls.py

url(r'^country-autocomplete/$', CountryAutocomplete.as_view(), name='country-autocomplete'),
url(r'^new_person/$', views.create_person, name='create_person'),

person_form.html

% extends 'base.html' %

% block content %
<div>
    <form action="" method="post">
        % csrf_token %
         person_form.as_p 
        <input type="submit" />
    </form>
</div>
% endblock %

% block footer %
<script type="text/javascript" src="http://dal-yourlabs.rhcloud.com/static/collected/admin/js/vendor/jquery/jquery.js"></script>

 form.media 
% endblock %

结果

问题:“出生国家”字段未填写,我也无法输入。

这是什么原因? 是否有可能是由加载在 base.html 上的 .js 生成的?

在base.html中加载

<script type="text/javascript" src="https://code.jquery.com/jquery-1.12.0.min.js"></script>

【问题讨论】:

不知道为什么这被否决了。这是一个有用的问题,似乎是尝试使用 django-autocomplete-light 时面临的常见问题。 【参考方案1】:

解决方案很简单:添加一些插件的 javascrips 和 css

<link href="/static/collected/autocomplete_light/vendor/select2/dist/css/select2.css" type="text/css" media="all" rel="stylesheet" />
<link href="/static/collected/autocomplete_light/select2.css" type="text/css" media="all" rel="stylesheet" />
<script type="text/javascript" src="/static/collected/autocomplete_light/autocomplete.init.js"></script>
<script type="text/javascript" src="/static/collected/autocomplete_light/select2.js"></script>

【讨论】:

我也有类似的问题,你把javascripts和css放在哪里了? in person_form.html【参考方案2】:

确保在模板中包含 form.media。

【讨论】:

为了更清楚,请确保在 form.media 之前包含 jquery.js !这是它对我有用的唯一方法。 &lt;script type="text/javascript" src="% static 'admin/js/vendor/jquery/jquery.js' %"&gt;&lt;/script&gt; form.media

以上是关于Django 自动完成灯:未填充字段的主要内容,如果未能解决你的问题,请参考以下文章

Django 自动完成灯 Select2 小部件未出现

html django自动完成灯适合100%

CSRF 令牌丢失或不正确 - 在 Django 中使用自动完成灯

根据自动完成选择填写表单集的其他两个字段

通过选择一个字段自动完成(自动填充)多个字段

如果表单有超过 200 个输入字段,则自动填充/自动完成不起作用