DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> JavaScript框架hover事件處理
JavaScript框架hover事件處理
編輯:關於JavaScript     

每個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函數傳遞了一個不明確的參數。

轉載地址:http://www.denisdeng.com/?p=720

原文地址:http://www.ibm.com/developerworks/web/library/wa-jsframeworks/index.html

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);

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved