我还在学习关于jQuery的知识,但我还没有找到一个可靠的答案。我知道你每次使用jQuery选择器$(...)
都会有性能上的损失,但是$(this)
有很大的开销吗?在你大量使用它之前,你应该缓存它吗?
var $this = $(this);
发布于 2010-10-05 00:44:06
如果你经常使用它,是的,它是有意义的,或者链,例如:
$(this).fadeIn().fadeOut().somethingElse();
如果很贵的话?不,在things...but的宏大计划中并非如此,如果你在一个循环中,成本会成倍增加,所以最好缓存它。如果你不止一次地使用它,那么它的意义有多大取决于我认为这段代码的性能有多重要。
发布于 2010-10-05 00:48:04
问得好杰森。我假设jQuery选择器函数相当有效地注意到this
关键字。也就是说,如果可以避免,不对同一个选择器进行重复调用是有意义的。这就是方法链接派上用场的地方:
$(this).hide().show().hide();
如果您打算在同一函数的不同点上多次使用同一选择器,我可能会创建一个变量来存储jQuery选择器函数的返回值。如果没有这一点,我就不会担心它,因为它实际上是一个非常非常小的done...especially处理,因为我非常确定jQuery库在运行任何正则表达式之前都会检查this关键字(和字符串类型)。
https://stackoverflow.com/questions/3857317
复制相似问题