今天在做表单提交的时候遇到一个问题,我用ajax去提交表单,使用一个submit类型的input去触发提交时间。然后就出现一个问题,快速点击按钮会触发多次提交。然后我就在点击的时候将input置为disable,在提交结束后再取消disable,但是没有效果。查了下资料发现这个方法貌似对input无效。
最后实在没办法,我就换了一个很原始的方法,在按钮下面加一个span标签,背景跟按钮一样。然后再出发点击事件时先把按钮隐藏,然后再ajax异步提交完成之后再显示按钮。很好的避免多次点击的问题,但是这个办法是在太麻烦了。像我这样的懒人实在不想用这种方法。(如果是做bug排除的话,还会涉及到样式方面的问题)。
最后在老大给了我提了一个方法,在点击的时候给按钮添加一个class:clicking。触发点击事件时判断这个按钮是否有这个class有的话就直接return false,在ajax提交结束后再去掉这个class。这个办法看起来是治标不治本,但是至少人畜无害,省了很多无谓的操作。还是挺好用的。
后面我自己做了几次试验,发现这个办法还能用在冒泡事件上:点击子节点触发父节点的点击事件等等。
如果发现按钮的disable不可用是可以试试这个办法。