jQuery给动态元素绑定事件

最近坐项目有一个需求是点击添加按钮后,出现文本框及提交按钮,提交文本后,添加按钮再次显示,如此循环。但问题来了,在提交文本后,再次显示的添加按钮,点击后不会出现文本框及提交按钮,原来的click事件已经失效。具体代码如下

 

<div class="creation">
     <a href="#" class="create">
          添加
     </a>
</div>

 

$(function(){
    addText();
}
function addText() {
   $('.creation').on('click','a',function() {
        $('.creation').html('<form action="#" οnsubmit="return false;"><input type="text" class="create-input" name="im" autofocus="" autocomplete="off"><button class="btn btn-primary btn-bm create-submit" οnclick="createText();">添加</button> </form>');
        });
}
function createText(){
    $.post(url,{key:value},function(){
        $('.creation').html('<a href="#" class="create"> 添加新印象 </a>');
    })
}

 

 

修改后,成功的代码如下:

  $('creation').on('click', 'a', function() {} //将原先的lick事件修改一下:添加一个参数'a'.

 虽然是小点,但也是一个坑,在此希望大家一块跨越这个坑。

还有一点就是:只要是from表单都会有默认的提交行为,致使页面刷新,即使你使用ajax请求,解决方法:

<from anction="#" οnsubmit="return false;"></form>

添加的return false,在别的事件也有应用比如<a>标签的默认跳转等等。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值