级联选择框与jQuery

时间:2013-07-16 20:40:38

标签: jquery cascadingdropdown

我想用html选择框和jQuery ajax帖子级联。当我选择一个选项时,它会将自己的值发送到另一个文件并获取json值。是的我用ajax帖子这样做。但在回调函数中,我将添加另一个选择框,设置所有jSON数据。我这样做是正确的。但是当我从添加的选择框中选择一个选项时,jQuery'更改'事件不处理这个新的选择框,并最终无法使用其他功能。

我的jQuery代码如下:

$(document).ready(function(){

    $("#kategoriler select").on('change',function(e){

        var catID = $(this).val();

        if($(this).next().is("select")){
            $(this).nextAll("select").remove();
        }

        console.log($(this));
        $.ajax({
            async: false,
            type: "POST",
            url: "ajax_cate_add",
            data: "catID=" + catID,

            success: function(data){

                if(data.length > 0){

                    var $parent = $("#kategoriler select:last").after("<select></select>").next();

                    for(var i = 0; i < data.length; i++){
                        $parent.append("<option value=" + data[i].id + ">" + data[i].tr_adi + "</option>");
                    }
                }
            }
        });
    });
});

启动HTML代码如下:

<div id="kategoriler">
    <select>
        <option value="8">Rezervasyon</option>
        <option value="7">E-Concierge</option>
        <option value="6">Özel F?rsatlar</option>
        <option value="5">Safira SPA &amp; Sa?l?k</option>
        <option value="4">Toplant? &amp; Davetler</option>
        <option value="3">Yeme &amp; ?çme</option>
        <option value="2">Odalar &amp; Süitler</option>
        <option value="1">Genel Bak??</option>
    </select>
</div>

但在我输入跟随代码的控制台中,它正在运行:

 $("select").change(function(){
      alert(2);
 });

从根选择框中选择一个选项,在上面的代码之后我输入控制台并从新选择框中选择一个选项,这些代码确实起作用并显示警告信息。

1 个答案:

答案 0 :(得分:1)

在绑定时,即在创建更改处理程序时,DOM中不存在元素(select元素)(因为它是动态生成的)。所以它不绑定任何change处理程序,因为没有要绑定的元素。因此,一个简单的解决方案是使用委托。现在,使用委托的好处在于,无论何时创建元素,处理程序都会被分配给元素。这应该是你的伎俩。

$(document).on('change','select', function(){
    alert('test');
});

PS:每当你必须动态创建元素时,你应该尝试使用委托。