使用jQuery在對象中緩存選擇器的簡單方法
當使用像jQuery這樣的庫時,開發(fā)者通常會使用選擇器來訪問和操作DOM中的元素。當一個選擇在頁面上被反復的訪問時,把它緩存起來以獲得更好的性能是個不錯的想法。
讓我們看一個例子,
jQuery(document).ready(function() { jQuery('#some-selector').on('hover', function() { jQuery(this).fadeOut('slow').delay(400).fadeIn(); console.log(jQuery(this).text()); }); jQuery('#another-element').on('hover', function() { jQuery(this).slideUp(); }); jQuery('#some-selector').on('click', function() { alert('You have clicked a featured element'); }); jQuery('#another-element').on('mouseout', function() { jQuery(this).slideUp(); }); });
也許你已經(jīng)注意到,ID ‘some-selector' 和 ‘a(chǎn)nother-element' 在上面的代碼片段中被提到了兩次。通過把這些選擇器保存到變量里,可以使他們能被復用,并且避免了重復選擇操作。
當你開始在你的jQuery代碼里積攢出各種各樣的選擇器時,你就能領(lǐng)會到在對象中緩存選擇器 – 以鍵值對的形式 – 是多么美好。這使得你更容易在腳本中的任何地方訪問它們,并且維護這些選擇器也是輕而易舉的事。
緩存選擇器后,改進過的代碼會像這樣,
var someNamespace_Dom = { someSelector : 'jQuery("#some-selector")', anotherElement: 'jQuery("#another-element")', }; jQuery(document).ready(function() { someNamespace_Dom.someSelector.on('hover', function() { jQuery(this).fadeOut('slow').delay(400).fadeIn(); console.log(jQuery(this).text()); }); someNamespace_Dom.anotherElement.on('hover', function() { jQuery(this).slideUp(); }); someNamespace_Dom.someSelector.on('click', function() { alert('You have clicked a featured element'); }); someNamespace_Dom.anotherElement.on('mouseout', function() { jQuery(this).slideUp(); }); });
由于選擇器已經(jīng)被緩存到變量中,DOM 樹不再需要被重復遍歷來尋找被操作的元素?!畇omeNamespace_Dom' 對象可以被用來添加更多鍵值對,使得維護工作很輕松。
相關(guān)文章
判斷jQuery是否加載完成,沒完成繼續(xù)判斷的解決方法
下面小編就為大家分享一篇判斷jQuery是否加載完成,如果沒完成繼續(xù)判斷的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12jQuery實現(xiàn)可用于博客的動態(tài)滑動菜單
這篇文章主要介紹了jQuery實現(xiàn)可用于博客的動態(tài)滑動菜單,實例分析了jQuery操作鼠標事件及css樣式實現(xiàn)動態(tài)滑動菜單的技巧,非常具有實用價值,需要的朋友可以參考下2015-03-03treepanel動態(tài)加載數(shù)據(jù)實現(xiàn)代碼
本文介紹一個treepanel動態(tài)加載數(shù)據(jù)的例子,需要了解的朋友可以參考下2012-12-12jQuery 選擇同時包含兩個class的元素的實現(xiàn)方法
下面小編就為大家?guī)硪黄猨Query 選擇同時包含兩個class的元素的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-06-06