假设我们正在制作待办事项列表,每当单击最后一个列表项时,如何附加新的列表项。 在下面的示例代码中,第四个列表项保留click事件,但我希望它每次都在最后一个列表项上。
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.5/jquery.js" type="text/javascript"></script>
<ul id="foo">
<li><input placeholder="One"></input></li>
<li><input placeholder="Two"></input></li>
<li><input placeholder="Three"></input></li>
<li><input placeholder="Click Me Add More"></input></li>
</ul>
<script>
$('#foo li:last-child').bind( "click", function(){
var li = $(this).clone();
$('#foo').append(li);
})
</script>
答案 0 :(得分:1)
对于jquery 1.7+,请使用:
$('#foo').on( "click","li:last-child", function(){
var li = $(this).off('click').clone();
$('#foo').append(li);
})
答案 1 :(得分:1)
试试这个
$('#foo li:last-child').bind( "click", function(){
var li = $(this).clone(true);
$('#foo li:last-child').unbind( "click");
$('#foo').append(li);
})
而是使用.on()
和.off()
$('#foo li:last-child').on( "click", function(){
var li = $(this).clone(true);
$('#foo li:last-child').off( "click");
$('#foo').append(li);
})
<强> Check Fiddle 强>
答案 2 :(得分:0)
我尝试使用bind而不是live
$('#foo li:last-child').live( "click", function(){
var li = $(this).clone();
$('#foo').append(li);
})
答案 3 :(得分:-1)
试试这个:http://jsfiddle.net/xu4wc/
$('#foo').on( "click","input:last-child", function(){
var li = $(this).parent().clone();
$('#foo').append(li);
})