- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我最近有一个关于如何使用 jQuery 正确检查元素是否存在的问题。我从这里找到了答案:
https://learn.jquery.com/using-jquery-core/faq/how-do-i-test-whether-an-element-exists/
总结:
if ( $( "#myDiv" ).length ) {
// Do something
}
和我一起工作的一个人说正确的检查方法应该是:
if ($( "#myDiv" ) && $( "#myDiv" ).length ) {
// Do something
}
重要吗?我的意思是从性能或延迟方面来看,它们的性能是否相同?
还有:
$( "#myDiv" ).show();
$( "#myDiv" ).hide();
$( "#myDiv" ).val('');
在这些类型的 jQuery 函数中,似乎不需要 if
检查,因为如果 #myDiv
不存在,它们不会引发错误,对吗?
为了它的值(value),我使用的是 jQuery 1.6.4。
最佳答案
One guy I work with says the correct way to check should be:
if ($( "#myDiv" ) && $( "#myDiv" ).length ) {
//do something
}
他错了,至少在 $( "#myDiv") &&
部分是这样。 jQuery 的 $(selector)
always 返回一个对象,根据定义它是真实的。所以那部分是没有意义的,并且无缘无故地重新查询 DOM。
I mean from a performance or latency wise, do they perform the same?
无缘无故地重新查询 DOM 是一种浪费,但大多数时候它在任何可观察的方面都无关紧要,尤其是对于像 $("#myDiv") 这样的 ID 选择器
由 jQuery 优化为对 getElementById
的调用(速度非常快)。所以一方面,是的,这是浪费额外的工作。另一方面,如今的浏览器速度如此之快,以至于您可能有更大的鱼要炸。但这可能是额外的无意义代码,这是更大的问题。
总的来说:jQuery 是基于集合的。这意味着对其中没有元素的集合的操作是空操作。例如:
$(".foo").addClass("bar");
...如果 DOM 中没有 .foo
元素,则为空操作(不是错误)。
因此,如果您关心是否匹配元素,请检查length
。如果您不关心并且只想对它们执行操作如果它们在那里,请继续执行操作(有一个重要的警告1)。
基本上,有三种情况:
你知道元素会在那里,所以检查没有意义
=> 不检查
您不知道元素会在那里,但您不关心并且只想对它们进行操作如果它们在那里
=> 不检查
您关心这些元素是否出于其他原因
=> 进行检查
1 这里有一个重要的警告:如果您调用的 jQuery 函数返回的不是 jQuery 对象(例如,val()
或 offset()
或 position()
等),当您在空集上调用它时,它通常会返回 undefined
(异常(exception)情况是 text()
,它将返回 ""
[text()
在几个方面不像其他的;这是其中之一])。因此,编写天真地假定这些东西会返回您所期望的内容的代码,即使集合为空,也会对您不利。
例如:
if ($(".foo").offset().top > 20)
...如果没有.foo
元素会抛出一个错误,因为offset()
会返回undefined
,而不是一个对象.
但这很好:
$(".foo").closest(".bar").toggleClass("baz"):
...因为即使没有 .foo
,closest()
也会返回另一个空的 jQuery 集,并调用 toggleClass()
上面是空操作。
因此,当处理不返回 jQuery 对象的访问器时,如果您不确定您正在处理一个至少包含一个元素的集合,您需要更多的防御措施,例如:
var offset = $(".foo").offset();
if (offset && offset.top > 20)
同样,大多数访问器(不返回 jQuery 对象)都这样做,包括 val()
、offset()
、position()
, css()
, ...
关于javascript - 我真的需要使用 jQuery 检查元素是否存在吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38751168/
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicate: Why can't Python handle true/false values as I expect?
我是不是遗漏了什么或者这是 ruby 中的错误? a = %w(foo bar baz) a.include? "foo" # => true a.size == 3
从 Modelica 文档来看,注释 Evaluate 似乎只对参数有影响: https://build.openmodelica.org/Documentation/ModelicaReferenc
为了避免嵌套的 if 语句并提高可读性,我想创建一个switch(true){ ... } Coldfusion 中的声明。我在 php 中经常使用这个,但是当我在 Coldfusion 中尝试这个时
嗨,我正在尝试处理 ajax json 响应 这是我的代码 success: function (j) { switch(true) { case (j.cho
我之前在我的 TF 代码中使用过这个: count = "${var.whatever == "true" ? 1 : 0}" 这非常适合我想要使用的东西。但是,我正在考虑如何最好地使用类似于说的
我之前在我的 TF 代码中使用过这个: count = "${var.whatever == "true" ? 1 : 0}" 这非常适合我想要使用的东西。但是,我正在考虑如何最好地使用类似于说的
这个问题在这里已经有了答案: How can I return pivot table output in MySQL? (10 个答案) 关闭 5 年前。 我正在尝试构建一个以唯一列值作为列名的表
我制作了一个简单的 JDialog,其中包含一个标签和一个按钮,它基本上相当于信息对话框。所以在对话框中,有一个方法 display() 我在其中调用了 setVisible(true) 五次。 据我
在 bash 4.2.8(1)-release (x86_64-pc-linux-gnu) 在 Ubuntu 11.04 上这个命令 [ $(wc -l /var/www/some.log|cut -
我正在使用 c 语言进行并发处理,我有一个进程池。为此,我让每个 child 都在一个 While (True) 循环中。为了杀死 child ,我正在使用一个全局变量和一个信号处理程序来修改它来打破
我正在尝试选择填写了字段的数据库条目。数据库有两种插入数据的方式,一种输入评论,一种不输入,我希望只选择填写了评论的行。 $requete = "SELECT * FROM daysoff WHER
如何在 JavaMail session 中setDebug(true) 捕获流并在我的日志记录框架中使用它? (缺少下载源代码,更改接受流作为参数的方法,重新编译它,...) 更一般地说,Java
我是 JavaScript 的新手,我刚刚发现了我无法理解的奇怪行为: var magicVar = Math.sin; magicVar == true; // it returns false m
对此感到困惑。 在两台服务器上运行相同版本的 MySQL。 (从完全相同的 rpm 构建)- 沿线的某个地方,一些开发人员改变了一些东西...... 服务器 1: mysql> select ( no
我在查看 OpenSSL 中使用的一些预处理器宏时,从 crypto/stack/safestack.h 中发现了以下内容: #define CHECKED_STACK_OF(type, p) \
所以我遇到了一个问题,我的正则表达式看起来像这样:/true|false/。 当我检查单词 falsee 时,我从这个正则表达式中得到一个 true,有没有办法将它限制为确切的 true 或 fals
我正在对这个恶意 JavaScript 行进行一些试验:var undefined = true; JavaScript 中每个未初始化的变量都有 undefined 的值,这只是一个保存特殊值 'u
我想将 PHP 的微时间存储为我在 MySQL 中的时间戳。 我去过told最好用 DECIMAL 存储它,但我找不到理想的大小。 有谁知道 microtime(true) 返回的最大大小是多少,所以
在 PHP 中,当您在 URL 中包含诸如“var=true”之类的内容时,URL 中的“true”和“false”是否被转换为 boolean 变量,或者它们是否等于文本“true”还是“假”?例如
我是一名优秀的程序员,十分优秀!