首页 > 语言 > JavaScript > 正文

使用jQuery在对象中缓存选择器的简单方法

2024-05-06 16:22:30
字体:
来源:转载
供稿:网友

这篇文章主要介绍了使用jQuery在对象中缓存选择器的简单方法,jQuery是最知名的JavaScript库,需要的朋友可以参考下

当使用像jQuery这样的库时,开发者通常会使用选择器来访问和操作DOM中的元素。当一个选择在页面上被反复的访问时,把它缓存起来以获得更好的性能是个不错的想法。

让我们看一个例子,

 

 
  1. jQuery(document).ready(function() { 
  2. jQuery('#some-selector').on('hover'function() { 
  3. jQuery(this).fadeOut('slow').delay(400).fadeIn(); 
  4. console.log(jQuery(this).text()); 
  5. }); 
  6.  
  7. jQuery('#another-element').on('hover'function() { 
  8. jQuery(this).slideUp(); 
  9. }); 
  10.  
  11. jQuery('#some-selector').on('click'function() { 
  12. alert('You have clicked a featured element'); 
  13. }); 
  14.  
  15. jQuery('#another-element').on('mouseout'function() { 
  16. jQuery(this).slideUp(); 
  17. }); 
  18. }); 

也许你已经注意到,ID ‘some-selector' 和 ‘another-element' 在上面的代码片段中被提到了两次。通过把这些选择器保存到变量里,可以使他们能被复用,并且避免了重复选择操作。

当你开始在你的jQuery代码里积攒出各种各样的选择器时,你就能领会到在对象中缓存选择器 – 以键值对的形式 – 是多么美好。这使得你更容易在脚本中的任何地方访问它们,并且维护这些选择器也是轻而易举的事。

缓存选择器后,改进过的代码会像这样,

 

 
  1. var someNamespace_Dom = { 
  2. someSelector : 'jQuery("#some-selector")'
  3. anotherElement: 'jQuery("#another-element")'
  4. }; 
  5.  
  6. jQuery(document).ready(function() { 
  7. someNamespace_Dom.someSelector.on('hover'function() { 
  8. jQuery(this).fadeOut('slow').delay(400).fadeIn(); 
  9. console.log(jQuery(this).text()); 
  10. }); 
  11. someNamespace_Dom.anotherElement.on('hover'function() { 
  12. jQuery(this).slideUp(); 
  13. }); 
  14. someNamespace_Dom.someSelector.on('click'function() { 
  15. alert('You have clicked a featured element'); 
  16. }); 
  17. someNamespace_Dom.anotherElement.on('mouseout'function() { 
  18. jQuery(this).slideUp(); 
  19. }); 
  20. }); 

由于选择器已经被缓存到变量中,DOM 树不再需要被重复遍历来寻找被操作的元素。‘someNamespace_Dom' 对象可以被用来添加更多键值对,使得维护工作很轻松。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选