简体   繁体   English

jQuery on(change)第二次不起作用

[英]jQuery on(change) doesn't work second time

I have cascading dropdown menus as below. 我有如下的级联下拉菜单。 I am listing selections dynamically on second and third dropdowns. 我在第二个和第三个下拉列表中动态列出选择。 While the first on change function works without problem (i am getting project list), the second on change ( $("#pro").on('change', function(e) ) simply doesn't sense any change on selection of projects. Chrome console shows no problem. What can be the problem? 虽然第一个on change函数可以正常工作(我正在获取项目列表),但是第二个on change($(“#pro”)。on('change',function(e))根本不会感觉到选择的任何变化的项目。Chrome控制台没有问题。可能是什么问题?

<div class="form-group">
  <label for="projectfamily">Proje Grubu</label>
  <select class="form-control" name="projectfamily" id="projectfam">
    <option value="">Seçiniz</option>
    @foreach($projectfamilies as $projectfamily)
    <option value= "{{$projectfamily->id}}">{{$projectfamily->projectfamily}}</option>
    @endforeach
  </select>
</div>

<div class="form-group">
  <label for="project">Proje Adı</label>
  <select class="form-control" name="project" id="pro">
    <option value= "" disabled></option>
  </select>
</div>

<div class="form-group">
  <label for="version">Versiyon</label>
  <select class="form-control" name="version" id="version">
    <option value="" disabled></option>
  </select>
</div>

JQuery JQuery的

$('#projectfam').on('change', function(e) {
    var projectfam = e.target.value;
    $.get('/ajax_projectfamily_post?projectfam=' + projectfam, function(data){
        $('#pro').empty();
        $('#version').empty();  
        $('#pro').append('<option value="' + '">' + "Seçiniz" + '</option>');

        $.each(data, function(i, deger){
            $('#pro').append('<option value="' + deger.id + '">' + deger.project + '</option>');
        });
    });
});

$("#pro").on('change', function(e) {
    var project = e.target.value;
    $.get('/ajax_project_post?project=' + project, function(data){
        $('#version').empty();
        $('#version').append('<option value="' + '">' + "Seçiniz" + '</option>'); 
        $.each(data, function(i, deger) {
            $('#version').append('<option value="' + deger.id + '">' + deger.version + '</option>');
        });
    });
});

It appears to work as expected in chrome. 它在chrome中似乎可以正常工作。 See this fiddle with the ajax calls replaced. 看到此小提琴替换了ajax调用。 Is it a problem with the ajax call? ajax调用有问题吗? Or perhaps an html syntax error? 还是html语法错误? Check the validity of your entire HTML page. 检查整个HTML页面的有效性。 Since you only posted a fragment I can't diagnose further. 由于您只发布了一个片段,因此无法进一步诊断。

$('#projectfam').on('change', function(e) {
    var projectfam = e.target.value;
    var data = ['a', 'b', 'c'];

    $('#pro').empty();
    $('#version').empty();  
    $('#pro').append('<option value="' + '">' + "Seçiniz" + '</option>');

    $.each(data, function(i, deger){
        $('#pro').append('<option value="' + data[i] + '">' + data[i] + '</option>');
    });
});

$("#pro").on('change', function(e) {
    var project = e.target.value;
    var data = ['x', 'y', 'z'];
    $('#version').empty();
    $('#version').append('<option value="' + '">' + "Seçiniz" + '</option>'); 
    $.each(data, function(i, deger) {
        $('#version').append('<option value="' + data[i] + '">' + data[i] + '</option>');
    });
});

I would do it like this, I had a similar problem before, the onchange events need to be assigned after the elements are loaded: 我会这样做,之前我有一个类似的问题,需要在元素加载后分配onchange事件:

$('#projectfam').on('change', function(e) {
    var projectfam = e.target.value;
    $.get('/ajax_projectfamily_post?projectfam=' + projectfam, function(data){
        $('#pro').empty();
        $('#version').empty();  
        $('#pro').append('<option value="' + '">' + "Seçiniz" + '</option>');

       $.each(data, function(i, deger){
            $('#pro').append('<option value="' + deger.id + '">' + deger.project + '</option>');
       });
       addOnChangeThingy(); // load onclick functions
   });
});

function addOnChangeThingy(){
   $("#pro").on('change', function(e) {
      var project = e.target.value;
      $.get('/ajax_project_post?project=' + project, function(data){
          $('#version').empty();
          $('#version').append('<option value="' + '">' + "Seçiniz" + '</option>'); 
          $.each(data, function(i, deger) {
             $('#version').append('<option value="' + deger.id + '">' + deger.version + '</option>');
           });
       });
   });
 }

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM