У меня есть Модель (Персоны), которую необходимо ввести с помощью ModelForm (PersonForm). models.py,
GENDER_CHOICES = [
('Male', 'Male'),
('Female', 'Female'),
]
MALE_CATEGORIES = [
('Male Category 1', 'Male Category 1'),
('Male Category 2', 'Male Category 2'),
('Male Category 3', 'Male Category 3'),
]
FEMALE_CATEGORIES = [
('Female Category 1', 'Female Category 1'),
('Female Category 2', 'Female Category 2'),
('Female Category 3', 'Female Category 3'),
]
def get_all_choices():
all_choices = MALE_CATEGORIES
all_choices+=FEMALE_CATEGORIES
return all_choices
class Person(models.Model):
name = models.CharField(max_length=50, unique=True)
gender = models.CharField(max_length=7, choices=GENDER_CHOICES)
category = models.CharField(max_length=20, choices=get_all_choices())
forms.py,
class PersonForm(ModelForm):
class Meta:
model = Person
fields = [
'name',
'gender',
'category',
]
views.py,
def personform_page(request):
context = {}
if request.method == 'POST':
personform = PersonForm(request.POST)
if personform.is_valid():
personform.save()
return redirect('personform_page')
context['personform'] = personform
else:
personform = PersonForm()
context['personform'] = personform
context['male_categories'] = MALE_CATEGORIES
context['female_categories'] = FEMALE_CATEGORIES
return render(request, 'app1/personform_page.html', context=context)
PersonForm имеет зависимый раскрывающийся список, из которого можно выбрать категорию будет зависеть от выбранного пола. В настоящее время я жестко кодирую выбор категории в JQuery следующим образом: personform_page. html,
<form class="form-class" action="" method="post" enctype="multipart/form-data">
{% csrf_token %}
{% for field in personform %}
<p>
{{ field.label_tag }}
{{ field }}
{% if field.help_text %}
<small style="color: black;"> {{ field.help_text }} </small>
{% endif %}
{% for error in field.errors %}
<p style="color: red;"> {{ error }} </p>
{% endfor %}
</p>
{% endfor %}
<button class="btn btn-outline-primary" type="submit">Join</button>
</form>
<script>
$(document).ready( function() {
$("#id_category").hide();
$("#id_gender").on('change', function(){
var gender = $("#id_gender").val();
if(gender == 'Male'){
$('#id_category').empty();
$("#id_category").show();
var maleCategories = ['Male Category 1', 'Male Category 2', 'Male Category 3'];
var length = maleCategories.length;
var i;
for(i=0; i < length; i++){
maleCategory = maleCategories[i];
$('#id_category').append(
`
<option value="${maleCategory}">
${maleCategory}
</option>
`
);
}
}
else if(gender == 'Female'){
$('#id_category').empty();
$("#id_category").show();
var femaleCategories = ['Female Category 1', 'Female Category 2', 'Female Category 3'];
var length = femaleCategories.length;
var i;
for(i=0; i < length; i++){
femaleCategory = femaleCategories[i];
$('#id_category').append(
`
<option value="${femaleCategory}">
${femaleCategory}
</option>
`
);
}
}
else{
$('#id_category').empty();
}
});
});
</script>
Как отправить выбор категории в JQuery без необходимости его жесткого кодирования? Нужно ли отправлять их как контекст или использовать что-то еще?