使用jQuery在對(duì)象中緩存選擇器的簡(jiǎn)單方法
當(dāng)使用像jQuery這樣的庫(kù)時(shí),開發(fā)者通常會(huì)使用選擇器來訪問和操作DOM中的元素。當(dāng)一個(gè)選擇在頁(yè)面上被反復(fù)的訪問時(shí),把它緩存起來以獲得更好的性能是個(gè)不錯(cuò)的想法。
讓我們看一個(gè)例子,
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' 在上面的代碼片段中被提到了兩次。通過把這些選擇器保存到變量里,可以使他們能被復(fù)用,并且避免了重復(fù)選擇操作。
當(dāng)你開始在你的jQuery代碼里積攢出各種各樣的選擇器時(shí),你就能領(lǐng)會(huì)到在對(duì)象中緩存選擇器 – 以鍵值對(duì)的形式 – 是多么美好。這使得你更容易在腳本中的任何地方訪問它們,并且維護(hù)這些選擇器也是輕而易舉的事。
緩存選擇器后,改進(jìn)過的代碼會(huì)像這樣,
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 樹不再需要被重復(fù)遍歷來尋找被操作的元素。‘someNamespace_Dom' 對(duì)象可以被用來添加更多鍵值對(duì),使得維護(hù)工作很輕松。
- jquery選擇器簡(jiǎn)述
- jQuery選擇器用法實(shí)例詳解
- jquery在ie7下選擇器的問題導(dǎo)致append失效的解決方法
- jQuery插件實(shí)現(xiàn)適用于移動(dòng)端的地址選擇器
- 簡(jiǎn)單講解jQuery中的子元素過濾選擇器
- 淺析jQuery事件之on()方法綁定多個(gè)選擇器,多個(gè)事件
- jQuery選擇器基礎(chǔ)入門教程
- jQuery選擇器及jquery案例詳解(必看)
- 淺談jQuery 選擇器和dom操作
- jQuery原理系列-css選擇器的簡(jiǎn)單實(shí)現(xiàn)
- jquery選擇器中的空格與大于號(hào)>、加號(hào)+與波浪號(hào)~的區(qū)別介紹
相關(guān)文章
判斷jQuery是否加載完成,沒完成繼續(xù)判斷的解決方法
下面小編就為大家分享一篇判斷jQuery是否加載完成,如果沒完成繼續(xù)判斷的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2017-12-12
jQuery實(shí)現(xiàn)可用于博客的動(dòng)態(tài)滑動(dòng)菜單
這篇文章主要介紹了jQuery實(shí)現(xiàn)可用于博客的動(dòng)態(tài)滑動(dòng)菜單,實(shí)例分析了jQuery操作鼠標(biāo)事件及css樣式實(shí)現(xiàn)動(dòng)態(tài)滑動(dòng)菜單的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-03-03
treepanel動(dòng)態(tài)加載數(shù)據(jù)實(shí)現(xiàn)代碼
本文介紹一個(gè)treepanel動(dòng)態(tài)加載數(shù)據(jù)的例子,需要了解的朋友可以參考下2012-12-12
jQuery使用一個(gè)按鈕控制圖片的伸縮實(shí)現(xiàn)思路
上一篇講解了jquery同時(shí)控制四張圖片的伸縮,想必大家對(duì)伸縮有一定了解了,本文將為大家介紹下使用按鈕控制圖片的伸縮,感興趣的朋友可以參考下哈2013-04-04
jQuery 選擇同時(shí)包含兩個(gè)class的元素的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄猨Query 選擇同時(shí)包含兩個(gè)class的元素的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06
jquery實(shí)現(xiàn)手風(fēng)琴展開效果
這篇文章主要為大家詳細(xì)介紹了jquery實(shí)現(xiàn)手風(fēng)琴展開效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07

