javascript - 实时 ('click' ) 和性能

标签 javascript jquery

我有一个网格,有一列包含 <a> <data-..> 中带有一些附加信息的 anchor 标记标签并有一个类名 <class='myspeciallink'> .在我不显眼的 JS 脚本中,我选择了所有具有该类名的元素并应用 live('click') .我需要它是 live() 因为网格是在运行时生成的。

live('click') 里面发生了什么处理程序?我使用该附加数据并添加 <div>到基于该数据的页面。它又用于生成 jQuery UI 对话框。它在我的电脑上运行良好。

但是!这在现实世界中如何运作?我应该为可能的性能影响而烦恼吗?感觉瞬间对十几个元素应用live()
会影响性能。特别是对于像我这样相当复杂的处理程序——它需要获取数据、解析数据、创建一个 div、应用一个对话框等等。

这闻起来像是糟糕的设计吗?您能否建议一种不同的方法,或者我的担忧是没有根据的?我可以使用某种分析器工具来查找我的 javascript 中的瓶颈吗?

UPD:仍然没有人建议使用任何分析工具。 firebug 和 chrome 开发工具很好,但也许还有更好的东西?

最佳答案

live("click") 实际上从性能的 Angular 来看更好:不是将事件处理程序绑定(bind)到每个匹配的元素,而是应用一个等待事件的事件处理程序冒泡,然后查看触发事件的元素是否匹配选择器 .live 被调用。

将其与 $('selector').click(...) 进行比较,后者确实遍历每个元素并绑定(bind)一个新的事件处理程序。 live('click') 没有额外的开销,无论有多少页面元素与其选择器匹配。根据您的选择器匹配的元素数量,使用 .live 可以避免在每个页面的初始加载期间延迟最多几秒钟。

但是,事件处理程序必须检查每个冒泡到其选择器的事件,以查看是否存在匹配项。这将为每个点击事件增加少量开销,但您的用户很可能不会注意到差异。

关于javascript - 实时 ('click' ) 和性能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6047193/

相关文章:

javascript - Bootstrap 模式对话框中的默认按钮

javascript - Sencha Touch 2 - 在 MVC 中添加监听器的正确方法?

javascript - 将鼠标悬停在表格单元格上时更改主体背景颜色

jquery - 在 url 中使用 # 打开模式

javascript - 如何使用 Jquery 仅在图标单击时显示日期选择器?

php - 保留复选框状态

javascript - Ajax 上传不工作 codeigniter

javascript - 在不破坏子级的情况下更改父级 <li> 的文本

javascript - NodeJS 项目到 EXE 文件

jquery - 使用 jquery ajax 请求解析 xml