在AJAX调用后,使用django变量填充下拉列表

时间:2020-03-08 20:04:57

标签: javascript django ajax dropdown

我有当选择一个新的值触发AJAX调用下拉。 AJAX脚本调用了我的Django视图,该视图返回一个变量(值列表)。直到我需要使用该列表中的值填充第二个下拉菜单的步骤之前,它似乎一直有效。我不知道该怎么做。

这是我的html代码:

<form class="wrapper" action="" method="post"> {% csrf_token %} 

  <select name="myVal" class="toChange">
    <option val="1">1</option>  
    <option val="2">2</option>   
  </select>

  <select id="dep" name="dep">  </select>


  <script type="text/javascript">
    function dropdownChange () {
      var selectedValue = $(".toChange option:selected").val();
      $.ajax({
              url: '/myApp/templates/3/',
              type: 'POST',
              data: {'myVal': selectedValue},
              success: function(result) {
                alert(result);
              }
              }); 
    }
    $(".toChange").change(dropdownChange);

  </script>

</form>

这是我的views.py文件:

@csrf_exempt
def MyView3(request):

    if request.method == 'POST' and request.is_ajax:

        myVariable = json.dumps(["1", "2", "3", "4", "a"]) 


        return HttpResponse(myVariable , content_type='application/json')
    else:
        return render(request,'home3.html')

当我在下拉菜单中选择一个新值时,它将触发AJAX调用,并且alert(result)行返回“ 1,2,3,4,a”。因此,这部分有效,但是我不知道如何在“ dep”下拉列表中填充这些值。

我一直试图在脚本中插入以下代码,但未产生任何结果:

    var select = document.getElementById("dep");
    var options = result
    for(var i = 0; i < options.length; i++) {
    var opt = options[i];
    var el = document.createElement("option");
    el.textContent = opt;
    el.value = opt;
    select.appendChild(el);

我不确定这段代码是不是放错了地方,还是不是正确的代码。有人知道我应该在这里做什么吗?谢谢

1 个答案:

答案 0 :(得分:1)

您可以在ajax请求的success属性中进行以下操作:

        success: function(data) {
            var str = '';
            data.forEach(function(opt){
                str += '<option value="' + opt + '">' + opt + '</option>';
            });
            document.getElementById("dep").innerHTML = str;
        }