- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在过去的几年里,我一直使用 YUI 所支持的 JavaScript 命名空间作为格式化 JavaScript 代码的默认方式。
总而言之,它在更复杂的环境中运行良好,在这些环境中,许多 Web 小部件可能在不同的时间粘在一起。
直到最近,我几乎总是通过从 namespace 对象本身调用处理程序来在 HTML 中使用添加的事件处理程序。
我最近一直在使用 JQuery,并且一直在 Ready 函数内部而不是 HTML 中设置处理程序。
随着我做的越来越多,JQuery 就绪函数的闭包似乎正在取代 namespace 对象。
我现在最终得到的(至少对于一个小部件/工具类型页面)是一个 namespace 对象,主要处理保存数据和一堆关闭的事件处理程序,我出于数据特定目的访问 namespace 对象。
我的问题是,处理闭包与 namespace 对象的最佳实践是什么,特别是与事件处理程序相关的?
或者,类似地,设置事件处理程序的最佳实践是什么,它们应该是“重量级”并自行处理处理,还是交给更多类似库的代码。就个人而言,跟踪许多单独的“重量级”事件处理程序的流程比较困难。
最佳答案
这是一个非常主观的问题。话虽这么说,我会尽力给出我认为每种方法的优缺点。
命名空间对象:
yourNamespace.events.someClickHandler = function(event) {...}
$(function() {
$("#someElement").click(yourNamespace.events.someClickHandler);
}
这种方法的第一个“缺点”是将事件处理程序与其连接分开。您可以通过在定义每个事件后连接每个事件来避免这种情况(就像我在上面的示例中所做的那样),但最终您的代码中会出现大量“$(function() {”行。
这种风格的另一个“缺点”是事件处理程序的长名称(例如“yourNamespace.events.someClickHandler”)。您可以使用别名:
var events = yourNamespace.events;
$("#someElement").click(events.someClickHandler);
和更短的命名空间名称可以在一定程度上缓解这个问题,但实际上没有办法解决它。
既然有这些缺点,为什么有人会使用命名空间模式呢?嗯,它的一个“优点”是这些事件是可以访问的。假设(出于调试目的)您想要记录传递给单击处理程序的事件对象。使用 Firebug 你可以做类似的事情:
var oldHandler = yourNamespace.events.someClickHandler;
var newHandler = function(e) {console.log(e); oldHandler(e);}
$("#someElement").unbind("click");
$("#someElement").click(yourNamespace.events.someClickHandler);
而且,甚至无需刷新页面,您就可以记录您的事件。
同样,这种风格还有一个可重用性的优点。如果您想创建一个与旧的类似的新点击处理程序,但也执行 x、y 和 z,您可以这样做:
yourNamespace.events.advancedClickHandler = function(event) {
yourNamespace.events.someClickHandler(e);
x(); y(); z();
}
现在相比之下,我们有“闭包”样式(我更愿意将其称为“匿名函数”样式)。
$(function() {
$("#someElement").click(function(event) {...});
}
这显然更简洁,处理程序的定义与连接尽可能接近,而且我认为它甚至使用了很少的内存,因为没有变量引用。但是,您将无法进行任何实时调试,您将无法将该处理程序连接到其他任何地方,或者在某个新处理程序中扩展它,或者类似的事情,因为您的处理程序仅暂时存在当你连接它时。
所以,希望这会有所帮助。根据我的经验,命名空间对象样式通常是首选方法,尤其是 JS 项目越核心/严肃。但它肯定有一些缺点;目前确实没有完美的(即完全干净/可重用的)方式来连接 JS 中的事件。
关于javascript - 在命名空间对象或闭包中将事件处理程序代码保存在哪里?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1015300/
我尝试根据表单元素的更改禁用/启用保存按钮。但是,当通过弹出按钮选择更改隐藏输入字段值时,保存按钮不受影响。 下面是我的代码。我正在尝试序列化旧的表单值并与更改后的表单值进行比较。但我猜隐藏的字段值无
我正在尝试保存模型的实例,但我得到了 Invalid EmbeddedDocumentField item (1) 其中 1 是项目的 ID(我认为)。 模型定义为 class Graph(Docum
我有一个非常奇怪的问题......在我的 iPhone 应用程序中,用户可以打开相机胶卷中的图像,在我的示例中 1920 x 1080 像素 (72 dpi) 的壁纸。 现在,想要将图像的宽度调整为例
目前,我正在使用具有排序/过滤功能的数据表成功地从我的数据库中显示图像元数据。在我的数据表下方,我使用第三方图像覆盖流( http://www.jacksasylum.eu/ContentFlow/
我的脚本有问题。我想按此顺序执行以下步骤: 1. 保存输入字段中的文本。 2. 删除输入字段中的所有文本。 3. 在输入字段中重新加载之前删除的相同文本。 我的脚本的问题是 ug()- 函数在我的文本
任何人都可以帮助我如何保存多对多关系吗?我有任务,用户可以有很多任务,任务可以有很多用户(多对多),我想要实现的是,在更新表单中,管理员可以将多个用户分配给特定任务。这是通过 html 多选输入来完成
我在 Tensorflow 中训练了一个具有批归一化的模型。我想保存模型并恢复它以供进一步使用。批量归一化是通过 完成的 def batch_norm(input, phase): retur
我遇到了 grails 的问题。我有一个看起来像这样的域: class Book { static belongsTo = Author String toString() { tit
所以我正在开发一个应用程序,一旦用户连接(通过 soundcloud),就会出现以下对象: {userid: userid, username: username, genre: genre, fol
我正在开发一个具有多选项卡布局的 Angular 7 应用程序。每个选项卡都包含一个组件,该组件可以引用其他嵌套组件。 当用户选择一个新的/另一个选项卡时,当前选项卡上显示的组件将被销毁(我不仅仅是隐
我尝试使用 JEditorPane 进行一些简单的文本格式化,但随着知识的增长,我发现 JTextPane 更容易实现并且更强大。 我的问题是如何将 JTextPane 中的格式化文本保存到文件?它应
使用 Docker 相当新。 我为 Oracle 11g Full 提取了一个图像。创建了一个数据库并将应用程序安装到容器中。 正确配置后,我提交了生成 15GB 镜像的容器。 测试了该图像的新容器,
我是使用 Xcode 和 swift 的新手,仍在学习中。我在将核心数据从实体传递到文本字段/标签时遇到问题,然后用户可以选择编辑和保存记录。我的目标是,当用户从 friendslistViewCon
我正在用 Java 编写 Android 游戏,我需要一种可靠的方法来快速保存和加载应用程序状态。这个问题似乎适用于大多数 OO 语言。 了解我需要保存的内容:我正在使用策略模式来控制我的游戏实体。我
我想知道使用 fstream 加载/保存某种结构类型的数组是否是个好主意。注意,我说的是加载/保存到二进制文件。我应该加载/保存独立变量,例如 int、float、boolean 而不是结构吗?我这么
我希望能够将 QNetworkReply 保存到 QString/QByteArray。在我看到的示例中,它们总是将流保存到另一个文件。 目前我的代码看起来像这样,我从主机那里得到一个字符串,我想做的
我正在创建一个绘图应用程序。我有一个带有 Canvas 的自定义 View ,它根据用户输入绘制线条: class Line { float startX, startY, stopX, stop
我有 3 个 Activity 第一个 Activity 调用第二个 Activity ,第二个 Activity 调用第三个 Activity 。 第二个 Activity 使用第一个 Activi
我想知道如何在 Xcode 中保存 cookie。我想使用从一个网页获取的 cookie 并使用它访问另一个网页。我使用下面的代码登录该网站,我想保存从该连接获得的 cookie,以便在我建立另一个连
我有一个 SQLite 数据库存储我的所有日历事件,建模如下: TimerEvent *Attributes -date -dateForMark -reminder *Relat
我是一名优秀的程序员,十分优秀!