2012-07-18 120 views
2

自动完成适用于静态字段,但它不适用于动态字段。jQuery-UI自动完成不适用于动态字段

我试过.live()方法,因为我无法让它正常工作。

这里是我的HTML:

<table> 
    <tr class="selectmatprimas"> 
     <td> 
      <input type="text" class="selectmatprima" /> 
      <input type="text" name="matprimas[]" /> 
     </td> 
    </tr> 
    <tr class="clone" style="display:none;"> 
     <td> 
      <input type="text" class="selectmatprima" /> 
      <input type="text" name="matprimas[]" /> 
     </td> 
    </tr> 
</table> 
<input type="button" value="addmore" id="addmore" /> 

这里是我的JS:

var src = [ 
    { 
     "label": "Mat\u00e9ria Prima 1", 
     "value": "1" 
    }, 
    { 
     "label": "Mat\u00e9ria Prima 2", 
     "value": "2" 
    } 
]; 

$("input.selectmatprima").autocomplete({ 
    source: src, 
    select: function (event, ui) { 
     event.preventDefault(); 
     this.value = ui.item.label; 
     $(this).next().val(ui.item.value); 
    }, 
    focus: function (event, ui) { 
     event.preventDefault(); 
     this.value = ui.item.label; 
     $(this).next().val(ui.item.value); 
    } 
}); 

$("input#addmore").click(function(){ 
    var a = $('tr.clone').html(); 
    var b = $('tr.selectmatprimas:last'); 
    b.after("<tr class='selectmatprimas'>"+a+"</tr>"); 
}); 

Online DEMO

正如你可以看到,当我点击addmore按钮,自动完成没有按在新的领域工作...

+3

我发现做这样的事情是将用最好的方式'.on' (因为'.live'被弃用)来处理动态加载输入的'click'或'focus'事件,然后在事件触发时设置自动完成 – MrOBrian 2012-07-18 17:06:49

回答

3

我只有皮毛与您的代码,但这里的工作version

的关键是jQuery的on()功能,您可以阅读有关here

+0

谢谢,它的工作原理!但是,更好地关注而不是关键? – silentw 2012-07-18 18:07:42

+0

只是这样做,因为你评论。再次检查链接。它将与两者兼容。 – 2012-07-18 18:10:10

+0

非常感谢,这是诀窍! – silentw 2012-07-18 18:11:08