Django-autocomplete-light如何从html获取数据?

时间:2015-08-23 21:36:51

标签: javascript jquery python django django-autocomplete-light

我无法从包含django-autocomplete-light生成的数据的HTML元素中获取数据。 这是表格的代码:

class ThreadForm(forms.Form):
topic = forms.CharField(label="Topic", max_length=255)
body = forms.CharField(label="Body", widget=forms.Textarea(attrs={'rows': '12', 'cols':'100'}))
tags = autocomplete_light.fields.MultipleChoiceField(choices=(tuple((tag.name, tag.name) for tag in Tag.objects.all())),
                                      label='Tags',
                                      widget=autocomplete_light.widgets.MultipleChoiceWidget('TagAutocomplete',
                                                                                    attrs={'class':'form-control',
                                                                                           'placeholder':'Tag'}
                                                                                     )
                                                  )

def save(self, author, created):
  topic = self.cleaned_data['topic']
  body = self.cleaned_data['body']
  tags = self.cleaned_data['tags']
  th = Thread(author = author,
              topic = topic,
              body = body,
              created = created,
                )
  rtags = []
  for tag in tags:
      sr = Tag.objects.get(tag)
      rtags.append(sr.name)
  th.save()
  Tag.objects.update_tags(th, tags)

和autocomplete_light_registry.py:

from threads.models import Thread
import autocomplete_light
from tagging.models import Tag

class TagAutocomplete(autocomplete_light.AutocompleteModelBase):
    search_fields = ['^name']
autocomplete_light.register(Tag, TagAutocomplete, attrs={
    'data-autocomplete-minimum-characters': 1,
},)

如您所见,我已更改了django-autocomplete应用。在base.py中我找到了一个变量choice_html_format = '<span data-value="%s" name="choice">%s</span>' 我添加了属性name以获取类似的数据:

tags = request.POST.get('name')

但这不起作用。我收到了"NoneType in not callable"这样的错误 我接下来尝试的是从choice_html更改base.py

def choice_html(self, choice):
    """
    Format a choice using :py:attr:`choice_html_format`.
    """
    return self.choice_html_format % (
        escape(self.choice_value(choice)),
        escape(self.choice_label(choice)))

这是原创功能,我已将choice_value(choice)更改为choice_label(choice)。并收到错误"invalid literal for int() with base 10: <tag_name_here>"。看起来data-value属性仅适用于int()类型(但我无法改变它,也许在js函数中,我不知道)。

最后,我试图获取每个标签的pk,然后通过经理获取名称。但我收到错误Cannot resolve keyword '4' into field. Choices are: id, items, name

我绝对相信有一种简单的方法可以执行我需要的任务。

1 个答案:

答案 0 :(得分:0)

autocomplete-light有一个名为widget.html的模板,该模板在模板中呈现:

...
{% block select %}
    {# a hidden select, that contains the actual selected values #}
    <select style="display:none" class="value-select" name="{{ name }}" id="{{ widget.html_id }}" multiple="multiple">
        {% for value in values %}
            <option value="{{ value|unlocalize }}" selected="selected">{{ value }}</option>
        {% endfor %}
    </select>
{% endblock %}
...

如您所见,此<select>元素包含自动完成小部件的所有选定选项。

它的名称(我们将在视图后面通过其name属性识别它)只是自动完成的名称('tags')。

现在您需要确保模板中的自动填充字段包含在<form>标记中,以便提交值(如果您尚未提交)。

下一步是检索视图中的数据:

request.POST.getlist('tags')

就是这样。您现在拥有所选值的主键列表:

>>> print(str(request.POST.getlist('tags'))
['1', '3', '4', '7', ...]