每個JavaScript框架都實現跨瀏覽器的事件處理,鼓勵你擺脫舊式的內聯附加事件而使用精簡的線性方法。看看清單6的jQuery例子,使用hover事件高亮顯示div元素。
清單6:使用jQuery附加hover事件
$('#the-box').hover(function() { $(this).addClass('highlight'); }, function() { $(this).removeClass('highlight'); });
這是jQuery的一個特殊事件,你會發現它提供了兩個函數。第一個在onMouseOver事件觸發時調用,第二個函數在onMouseOut事件觸發時調用。這是因為hover沒有標準的DOM事件。讓我們看看更為典型的事件,如click(瞧瞧清單7):
清單7:使用jQuery附加click事件
$('#the-button').click(function() { alert('You pushed the button!'); });
正如你看到的那樣,實例中只有一個函數參數。jQuery中大多數事件均采用同樣的方式處理,在jQuery中使用事件處理程序,上下文指的是觸發事件的哪個對象。一些框架并不以這種方式工作,拿Prototype來說,清單7中的代碼看起來就像清單8中的那樣。
清單8:使用Prototype附加click事件
$('the-button').observe('click', function(e) { alert('You pushed the button!'); });
你首先會注意到,沒有click函數,而是一個observe函數,它在引用自身之前接受一個事件參數。您還會注意到該函數接受一個參數e,這里的上下文指的是觸發事件的元素。看看它如何工作,讓我們用Prototype重寫清單6中的代碼(看清單9)。
清單9:使用Prototype附加懸停事件
$('the-box').observe('mouseover', function(e) { var el = Event.element(e); el.addClassName('highlight'); }); $('the-box').observe('mouseout', function(e) { var el = Event.element(e); el.removeClassName('highlight'); });
jQuery也不同,你只需要使用$函數得到上下文變量,Prototype庫則使用Event.element() 函數。此外,你注意到你需要將mouseover和mouseout 事件分開。
通過該文章的一些教程,你可以看到函數以內聯的方式創建,并不命名。這意味著它不能重復使用,Prototype的懸停示例也給了我們一個如何使用命名函數的機會。清單10說明了這個方法。
清單10:使用Prototype改進懸停事件
您會注意到,此時你只需定義一個函數。它同時被mouseover和mouseout事件調用。該函數根據元素是否有“highlight”的類名,并基于結果添加或刪除之。你也會注意到,參數e隱式傳遞。換句話說,你給observe函數傳遞了一個不明確的參數。
function toggleClass(e) { var el = Event.element(e); if(el.hasClassName('highlight')) row.removeClassName('highlight'); else row.addClassName('highlight'); }
$('the-box').observe('mouseover', toggleClass); $('the-box').observe('mouseout', toggleClass);