记一次事件委托在 ios 下的兼容 bug

项目中碰到的兼容类 bug,记录一二。

页面上有几个同类型的控件,点击它们会触发一些事件,很显然,事件委托优于批量绑定。为了图方便,我将 click 事件绑定到了 document.body 上(绑定在 document 上也是一样),在安卓机上反应良好,ios 上居然不会触发点击事件!

试着将事件绑定到了控件的父级元素,问题消失了。

事实上,当使用事件委托给一个元素添加 click 事件时,如果事件是委托到 document 或 body 上,并且委托的元素是默认不可点击的(如 div, span 等),此时 click 事件会失效。如果是可点击的(比如 button、a 标签),此时 click 事件还是有效的,这点要特别注意。

Read More:

  • Click event delegation on the iPhone
  • iOS下click事件不冒泡的解决
  • iOS Safari 中点击事件失效的解决办法

你可能感兴趣的:(记一次事件委托在 ios 下的兼容 bug)