我正在努力寻找最有效的方式来挂起事件。
让我们想象一下我们有这样的结构:
<ul>
<li> 1st li </li>
...
<li> 99999th li </li>
<ul>
所以,我们有大约 10000 个 li 元素,我们想为所有这些元素添加事件监听器,假设我们也可以使用 jQuery。
第一个想法
<li onclick="console.log(this)" >...</li>
这个解决方案的坏部分 - 我们增加了 html 标记的大小,因为总是重复 onlick。
第二个想法
$('ul li').on('click', function(){
console.log(this)
})
当然这个解决方案不是一个选项,因为我们添加了 10000 个事件监听器,显然不利于性能。
第三个想法,事件委托
$('ul').on('click', 'li', function(){
console.log(this)
})
对我来说看起来真的很好,我们只使用一个事件监听器,而不是废弃的 html 标记,它可以根据我们的需要工作。
所以,我问了这个问题,因为有时我会查看不同站点的来源,其中很大一部分使用第一种方式。为什么?第一种方式有一些优势吗?
我想这可能是因为它更容易捕捉到页面中动态添加的元素,但可能有一些我不知道的东西?