python - 如果下拉列表为空而不显示,我如何从前端检查?

标签 python html django

我看到这可以使用 AJAX 来实现,但我对它不是很熟悉,而且我不确定如何处理它,因为我的 html 是有限的。

我有一个表单,其中包含依赖外键的下拉菜单。第一个下拉列表中的一些选项导致第二个没有任何选项,在这种情况下我希望它不出现,而不必刷新页面。

我的页面有一个关于如何制作这些依赖下拉列表的教程的 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 %}

还包括我的 views.py 中的 load_stations,以防它有任何帮助。

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 %}

最佳答案

如代码所示,您可以按如下方式修改您的 JS:

$("#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);
            // Check the length of the options child elements of the select
            if ($("#id_station_number option").length == 1) {
                $("#id_station_number").parent().hide(); // hide parent of the <select node (as your code, the <div> containing the input and the help_text)
            } else {
                // If any option, ensure the select is shown
                $("#id_station_number").parent().show();
            }
        }
     });
});

如您所见,检查所需选择内选项的长度应该可以解决问题。

如果用户更改相关仓库值时存在任何选项,则 else 语句将再次显示 select。


一些注意事项

  • 您可以避免创建 <option value="">---------</option>使用 forloop.first if 声明到你的 station_number_dropdown_options.html ,如果这样做,则必须更改对 <option 长度的检查在 JavaScript 中将元素设置为 0 而不是 1

  • 评估使用class Media在您的表单中包含它的相关脚本(如果需要,还有 css),文档在这里 -> https://docs.djangoproject.com/en/2.2/topics/forms/media/ )

希望对你有帮助

关于python - 如果下拉列表为空而不显示,我如何从前端检查?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58626207/

相关文章:

python - 在 pandas 中聚合多个数据类型时如何获得一致的行为?

python - 使用 pandas 总结分类问卷数据

python - Django View 安全性和最佳实践

django - 使用 django 模型表单中的现有数据填充 CheckboxSelectMultiple

python - 如何将参数分组为程序帮助消息的部分

Python字典内存使用

html - 在视口(viewport)和页面上都具有 100% 高度的 block

html - css 列表样式中的 upper-alpha 和 upper-latin 有什么区别?

html - 视网膜屏幕上的 Chrome 渲染伪影

django - 从请求uri获取 View 功能?