自动完成适用于静态字段,但它不适用于动态字段。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>");
});
正如你可以看到,当我点击addmore按钮,自动完成没有按在新的领域工作...
我发现做这样的事情是将用最好的方式'.on' (因为'.live'被弃用)来处理动态加载输入的'click'或'focus'事件,然后在事件触发时设置自动完成 – MrOBrian 2012-07-18 17:06:49