用‘on’函数为一个新增的按钮绑定了一个事件,这是事件会触发多次。

<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>码上飘</title>
    <script src="/FrontStyle/js/jquery-1.11.2.min.js" type="text/javascript"></script>
    <script>
        $(function(){
            $('#btn1').click(function () {
                $('#btnBind').on('click',function () {
                    alert(123);
                });
            });
        })
    </script>
</head>
<body>
<input id="btn1" type="button"  value="确认" />
<input id="btnBind" type="button" value="绑定按钮" />
</body>
</html>

  

 如上面的代码,如果你点击多次'btn1'按钮,那么就会绑定多少次click事件到'btnBind'按钮上,on是绑定多少次就触发多少次的。

解决方案:

  1.要想它只绑定一次,可以先'off'解绑然后再'on'。

$('#btnBind').off('click').on('click',function () {
    alert(123);
});

 2.执行一次后解绑unbind()

 $('#btn1').click(function () {
         $('#btnBind').on('click',function () {
             alert(123);
         });
$("#btnBind").unbind("click") });

    

); 

posted on 2016-08-25 20:30  加勒比海盗kk  阅读(5346)  评论(0编辑  收藏  举报