Я видел, что это может быть достигнуто с помощью AJAX, но я не очень знаком с ним, и я не уверен, как подойти к нему, так как мой HTML ограничен.
У меня есть форма, в которой есть выпадающие списки, зависящие от ForeignKey. Некоторые параметры в первом раскрывающемся списке приводят к тому, что у второго нет никаких параметров, и в этом случае я бы хотел, чтобы он не отображался без обновления страницы.
На моей странице есть запрос ajax отучебник о том, как сделать эти зависимые выпадающие списки, но я не мог понять, как создать запрос, чтобы проверить, является ли station_number пустым или нет, возможно, чтобы скрыть / показать из div, или что-то в этом родесортировать, не уверен, что это возможно
enter_exit_area.html
{% block main %}
<form id="warehouseForm" action="" method="POST" data-stations-url="{% url 'operations:ajax_load_stations' %}" novalidate >
{% csrf_token %}
<div>
<div>
{{ form.adp_number.help_text }}
{{ form.adp_number }}
</div>
<div>
{{ form.work_area.help_text }}
{{ form.work_area }}
</div>
<div>
{{ form.station_number.help_text }}
{{ form.station_number }}
</div>
</div>
<div>
<div>
<button type="submit" name="enter_area" value="Enter">Enter Area</button>
<button type="submit" name="leave_area" value="Leave">Leave Area</button>
</div>
</div>
</form>
<script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
<script>
$("#id_work_area").change(function () {
var url = $("#warehouseForm").attr("data-stations-url");
var workAreaId = $(this).val();
$.ajax({
url: url,
data: {
'work_area': workAreaId
},
success: function (data) {
$("#id_station_number").html(data);
}
});
});
</script>
{% endblock main %}
, включая load_stations из моего views.py в случае, если это полезно в любомway.
def load_stations(request):
work_area_id = request.GET.get('work_area')
stations = StationNumber.objects.filter(work_area_id=work_area_id).order_by('name')
return render(request, 'operations/station_number_dropdown_options.html', {'stations': stations})
station_number_dropdown_options.html
<option value="">---------</option>
{% for station in stations %}
<option value="{{ station.pk }}">{{ station.name }}</option>
{% endfor %}