繁体   English   中英

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

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

我有如下的级联下拉菜单。 我在第二个和第三个下拉列表中动态列出选择。 虽然第一个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的

$('#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>');
        });
    });
});

它在chrome中似乎可以正常工作。 看到此小提琴替换了ajax调用。 ajax调用有问题吗? 还是html语法错误? 检查整个HTML页面的有效性。 由于您只发布了一个片段,因此无法进一步诊断。

$('#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>');
    });
});

我会这样做,之前我有一个类似的问题,需要在元素加载后分配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