Chcę użyć widżetu select2 dla manytomanyfield w django. Istnieje kilka modułów django/select2, ale dokumentacja jest myląca i nie mogę znaleźć prostego przykładu tego, czego chcę. Dzięki za pomoc.W django, jak korzystać z widgetu select2 dla wielutany?
Odpowiedz
Dobre miejsce na rozpoczęcie jest django-select2, mają również dobrą pracę example również.
Tutaj po prostu dowiedzieć się główny pomysł w kontekście ich przykładem
modelu
@python_2_unicode_compatible
class Album(models.Model):
title = models.CharField(max_length=255)
artist = models.ForeignKey(Artist)
featured_artists = models.ManyToManyField(Artist, blank=True, related_name='featured_album_set')
primary_genre = models.ForeignKey(Genre, blank=True, null=True, related_name='primary_album_set')
genres = models.ManyToManyField(Genre)
def __str__(self):
return self.title
Pola jakie są zostaną odwzorowane na Select2 przedstawiony tutaj z ManyToMany typu relacji.
forma
class AlbumSelect2WidgetForm(forms.ModelForm):
class Meta:
model = models.Album
fields = (
'artist',
'primary_genre',
)
widgets = {
'artist': Select2Widget,
'primary_genre': Select2Widget,
}
Jest bardzo łatwo dostosować Select2Widget, jeśli to będzie potrzebne.
A końcowy - HTML część
{% load staticfiles %}
<!DOCTYPE html>
<html>
<head>
{{ form.media.css }}
<style type="text/css">
select {
width: 200px;
}
</style>
</head>
<body>
<form method="post" action="">
{% csrf_token %}
{{ form }}
<input type="submit" value="Submit Form"/>
</form>
<script src="{% static '//code.jquery.com/jquery-2.1.4.min.js' %}"></script>
<script type="text/javascript">
window.onerror = function (msg) {
$("body").attr("JSError", msg);
}
</script>
{{ form.media.js }}
</body>
Dziękuję bardzo za twój przykład pracy. – Sardathrion
w Django> = 2,0,
atrybutów Nowe ModelAdmin.autocomplete_fields i ModelAdmin.get_autocomplete_fields() przy użyciu metody pozwalają Select2 przeszukiwania widget dla ForeignKey i ManyToManyField.
Źródło: https://docs.djangoproject.com/en/2.0/releases/2.0/#minor-features
django-wybierz 2-formy robi to niezwykle proste. – user1993015