- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以,这可能是一个非常简单的问题,但我还是会问。这显然只是为了在我的脑海中澄清这两个语句是如何工作的。
场景我通过 Ajax 调用拉取一些 JSON,然后将其插入到具有一些选择器的 html 中。像这样:
$.each(r, function(k,v){
str+='location: <div class=\'loc-to-select\' data-location-id=\'' + v.id + '\'>';
str+= v.name + '</div>';
});
$('#event-search-locations').html(str);
基本上写出:
<div class='loc-to-select' data-location-id='2'>Joe's</div>
我有这两段 jQuery:
// doesn't work
$('.loc-to-select').on('click',function(){
alert('here you go');
});
// does work
$(document).on('click','.loc-to-select', function(){
alert('here you go');
});
所有这一切显然都发生在 jQuery 的 $(document).ready 完成触发之后。据我了解,这是 jQuery 提供的主要功能。我熟悉事件冒泡的概念。我还在这里阅读了文档 http://api.jquery.com/on/其中讨论委托(delegate)事件。我内部不理解 jQuery 如何通过后代元素做到这一点。其中一些讨论了它如何从用户空间 pov 进行处理:Direct vs. Delegated - jQuery .on()
此外,出于性能原因,似乎首选后代元素技术。后代元素模型基本上是说,如果我们将新内容添加到 DOM,请检查它是否符合“委托(delegate)元素”模型,而直接事件会绕过这个模型?
在更简单的层面上,jQuery“运行时”本质上是监视 DOM 的更改,然后检查还是提前检查 html 函数(本质上是通过 html 解析它所知道的项目)?
最后,为什么他们不将第二种语法(委托(delegate)语法)设为默认语法?它似乎提供了更大的特异性和更好的性能(如文档中提到的)
谢谢
最佳答案
我不能 100% 确定您想知道什么,因为您链接到的问题 (Direct vs. Delegated - jQuery .on()) 似乎包含您所问问题的答案。
这里再次解释差异:
$('.loc-to-select').on('click',function(){
alert('here you go');
});
将搜索当时存在的所有 .loc-to-select
元素,并将事件处理程序绑定(bind)到每个元素。
使用 DOM API 的等效内容是:
var elements = document.getElementsByClassName('loc-to-select');
for(var i = 0, l = elements.length; i < l; i++) {
elements[i].onclick = handler;
}
现在考虑
$(document).on('click','.loc-to-select', function(){
alert('here you go');
});
仅将一个事件处理程序绑定(bind)到 document
。它会检查每个点击事件,并测试它是否源自或位于类为 loc-to-select
的元素内。
同样,DOM 等效项(简化):
document.body.onclick = function(event) {
if(event.target.className === 'loc-to-select') {
handler.call(this);
}
}
<小时/>
jQuery 不会监视 DOM 的更改,它只是利用事件在树中冒泡的事实。
Finally, why don't they just make the second syntax (the delegated syntax) the default? It would seem to provide greater specificity and better performance (as mentioned in the docs)
让我们再次回顾一下事件委托(delegate)中发生的情况:单个事件处理程序绑定(bind)到一个元素以处理多个(相似)元素。这意味着您只需搜索并触摸 x
元素即可处理 y
元素,其中 x << y
,即设置速度更快。
但它需要权衡:由于事件首先遍历树并且必须评估原点,无论它是否匹配,因此在事件发生时处理事件需要更多时间。
想一想,如果您对页面上的所有点击事件使用事件委托(delegate),并将处理程序绑定(bind)到 document
,会发生什么情况。您最终会得到绑定(bind)到 n
的 document
事件处理程序,并且每个事件处理程序都将通过一次点击执行。但在这些 n
中,只有一个需要执行。这似乎性能不太好。
使用直接事件处理,设置速度会更慢,因为您必须找到所有元素并将事件处理程序绑定(bind)到每个元素。如果元素不多,那不是问题,但如果元素很多,那就有问题了。显然,绑定(bind)的事件处理程序越多,浏览器的性能就越差,但这可能会改变或已经改变了。
这是将许多事件处理程序绑定(bind)到许多执行较少次数的元素与将少数事件处理程序绑定(bind)到少数执行多次的元素之间的权衡。
关于jquery - jQuery 的这两部分有何不同以及直接事件模型和委托(delegate)事件模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11972657/
可不可以命名为MVVM模型?因为View通过查看模型数据。 View 是否应该只与 ViewModelData 交互?我确实在某处读到正确的 MVVM 模型应该在 ViewModel 而不是 Mode
我正在阅读有关设计模式的文章,虽然作者们都认为观察者模式很酷,但在设计方面,每个人都在谈论 MVC。 我有点困惑,MVC 图不是循环的,代码流具有闭合拓扑不是很自然吗?为什么没有人谈论这种模式: mo
我正在开发一个 Sticky Notes 项目并在 WPF 中做 UI,显然将 MVVM 作为我的架构设计选择。我正在重新考虑我的模型、 View 和 View 模型应该是什么。 我有一个名为 Not
不要混淆:How can I convert List to Hashtable in C#? 我有一个模型列表,我想将它们组织成一个哈希表,以枚举作为键,模型列表(具有枚举的值)作为值。 publi
我只是花了一些时间阅读这些术语(我不经常使用它们,因为我们没有任何 MVC 应用程序,我通常只说“模型”),但我觉得根据上下文,这些意味着不同的东西: 实体 这很简单,它是数据库中的一行: 2) In
我想知道你们中是否有人知道一些很好的教程来解释大型应用程序的 MVVM。我发现关于 MVVM 的每个教程都只是基础知识解释(如何实现模型、 View 模型和 View ),但我对在应用程序页面之间传递
我想realm.delete() 我的 Realm 中除了一个模型之外的所有模型。有什么办法可以不列出所有这些吗? 也许是一种遍历 Realm 中当前存在的所有类型的方法? 最佳答案 您可以从您的 R
我正在尝试使用 alias 指令模拟一个 Eloquent 模型,如下所示: $transporter = \Mockery::mock('alias:' . Transporter::class)
我正在使用 stargazer 创建我的 plm 汇总表。 library(plm) library(pglm) data("Unions", package = "pglm") anb1 <- pl
我读了几篇与 ASP.NET 分层架构相关的文章和问题,但是读得太多后我有点困惑。 UI 层是在 ASP.NET MVC 中开发的,对于数据访问,我在项目中使用 EF。 我想通过一个例子来描述我的问题
我收到此消息错误: Inceptionv3.mlmodel: unable to read document 我下载了最新版本的 xcode。 9.4 版测试版 (9Q1004a) 最佳答案 您没有
(同样,一个 MVC 验证问题。我知道,我知道......) 我想使用 AutoMapper ( http://automapper.codeplex.com/ ) 来验证我的创建 View 中不在我
需要澄清一件事,现在我正在处理一个流程,其中我有两个 View 模型,一个依赖于另一个 View 模型,为了处理这件事,我尝试在我的基本 Activity 中注入(inject)两个 View 模型,
如果 WPF MVVM 应该没有代码,为什么在使用 ICommand 时,是否需要在 Window.xaml.cs 代码中实例化 DataContext 属性?我已经并排观看并关注了 YouTube
当我第一次听说 ASP.NET MVC 时,我认为这意味着应用程序由三个部分组成:模型、 View 和 Controller 。 然后我读到 NerdDinner并学习了存储库和 View 模型的方法
Platform : ubuntu 16.04 Python version: 3.5.2 mmdnn version : 0.2.5 Source framework with version :
我正在学习本教程:https://www.raywenderlich.com/160728/object-oriented-programming-swift ...并尝试对代码进行一些个人调整,看看
我正试图围绕 AngularJS。我很喜欢它,但一个核心概念似乎在逃避我——模型在哪里? 例如,如果我有一个显示多个交易列表的应用程序。一个列表向服务器查询匹配某些条件的分页事务集,另一个列表使用不同
我在为某个应用程序找出最佳方法时遇到了麻烦。我不太习惯取代旧 TLA(三层架构)的新架构,所以这就是我的来源。 在为我的应用程序(POCO 类,对吧??)设计模型和 DAL 时,我有以下疑问: 我的模
我有两个模型:Person 和 Department。每个人可以在一个部门工作。部门可以由多人管理。我不确定如何在 Django 模型中构建这种关系。 这是我不成功的尝试之一 [models.py]:
我是一名优秀的程序员,十分优秀!