1

我正在尝试根据txtCols在其onkeyup函数上指定的 int 值创建下拉列表,如下所示:

$("#txtCols").keyup(function(){ 
    var $count = $(this).val();

    $("#holder").html('');

    // define matrix header options available
    var matrixHeaders = {
        'TB': 'Text Box',
        'DD': 'Drop Down',
        'CL': 'Calendar'
    }

    for ($i=0;$i<$count;$i++) 
    { 

        var s = $('<select id="header'+$i+'"/>');
        for(var val in matrixHeaders) {
            $('<option />', {value: val, text: matrixHeaders[val]}).appendTo(s);
        }
        s.appendTo('#holder');
    } 

}); 

下拉菜单是使用id='header+i' [increment variable] 生成的.

我的代码是这样的:

$(function(j) {
   $('#header' + j).change(function() {
      alert('Got Value');
   });
}(j));

也试过:

$(document).on('change', '#header' + j, function() {        
  alert('hii');
}(j));

但是这个事件不起作用。

4

2 回答 2

3

使用 on 函数让处理程序调用动态添加的元素:

$(document).on('change', '#header' + j, function() {

或者,对于任何j

$(document).on('change', '[id^="header"]', function() {

但我宁愿使用一个类而不是一个匹配 id 开头的选择器:

$(document).on('change', '.header', function() {
...
var s = $('<select class=header id="header'+$i+'"/>');
于 2012-10-26T10:33:52.650 回答
1

尝试这个:

首先将类添加到您的选择中,例如: select id="header'+$i+'" class="header"/

下一个添加处理程序:

$(".header").live("change", function () {
    var id = $(this).attr("id").split("header").join(""); //get i
    var opt = $("#header" + id + " option:selected").val(); //or whatever you need
    switch (opt) {
      case ..
    }
});
于 2012-10-26T10:49:33.587 回答