我想用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 & Sa?l?k</option>
<option value="4">Toplant? & Davetler</option>
<option value="3">Yeme & ?çme</option>
<option value="2">Odalar & Süitler</option>
<option value="1">Genel Bak??</option>
</select>
</div>
但在我输入跟随代码的控制台中,它正在运行:
$("select").change(function(){
alert(2);
});
从根选择框中选择一个选项,在上面的代码之后我输入控制台并从新选择框中选择一个选项,这些代码确实起作用并显示警告信息。
答案 0 :(得分:1)
在绑定时,即在创建更改处理程序时,DOM中不存在元素(select
元素)(因为它是动态生成的)。所以它不绑定任何change
处理程序,因为没有要绑定的元素。因此,一个简单的解决方案是使用委托。现在,使用委托的好处在于,无论何时创建元素,处理程序都会被分配给元素。这应该是你的伎俩。
$(document).on('change','select', function(){
alert('test');
});
PS:每当你必须动态创建元素时,你应该尝试使用委托。