2011-05-15 75 views
10

我想滾動div的內容與mousewheel jquery插件。我有這個,但它不工作。有什麼想法嗎?jquery mousewheel

$(function() { 
$('#contentBox').bind('mousewheel', function(event, delta) { 
    if (delta > 0) { 
     $('#contentBox').css('top', parseInt($('#contentBox').css('top'))+40); 
    } else { 
     $('#contentBox').css('top', parseInt($('#contentBox').css('top'))-40); 
    } 
    return false; 
}); 
}); 
+0

真正的答案:http://stackoverflow.com/questions/8886281/event-wheeldelta-returns-undefined?lq=1 – 2012-12-21 21:34:44

回答

7

只是一個猜測:添加+'px'的CSS值修復的東西嗎?其實,'媒體'是指什麼?

UPDATE

OK,我有機會來測試你的代碼,這一切看起來不錯,假設你已經設置的CSS正確。您是否已經爲#contentBox分配了top的值?沒有現有值,parseInt($('#contentBox').css('top'))將返回NaN。下面是我使用的代碼:

$(function() { 
    $('#contentBox').bind('mousewheel', function(event, delta) { 

     $('#contentBox').css('top', parseInt($('#contentBox').css('top')) + (delta > 0 ? 40 : -40)); 

     return false; 
    }); 
}); 

#contentBox { height: 4em; background-color: #eee; border: 1px solid #ccc; position: absolute; top: 100px; width: 200px; } 

<div id="contentBox"></div> 

請注意,我用三元運算符,以簡化/減少代碼了一下,但這只是爲了保持這個答案倒有幾分的大小,完全是可選的。我也在那裏用了一些測試CSS來看看我在做什麼;我相信你們是不同的!

+0

不好意思見上文編輯。我打電話#contentBox作爲媒體在一個點,但是沒有工作要麼 – user520300 2011-05-15 21:14:44

+0

加+'px'沒有工作要麼 – user520300 2011-05-15 21:16:48

+0

我知道這是顯而易見的,但delta和你的.css。('頂'的console.log() ...)電話會告訴你問題在哪裏。 – 2011-05-15 21:20:07

3

如果您使用jQuery 1.6,你可以寫:

$('#contentBox').css('top','+=40'); 

,並忘掉它。

很明顯,你仍然需要CSS來正確聲明#contentBox處於絕對定位狀態。

15
$('#contentBox').bind('mousewheel DOMMouseScroll', function(event) { 
    event.preventDefault(); 
    var delta = event.wheelDelta || -event.detail; 
    $(this).css({'top': $(this).position().top + (delta > 0 ? '+=40' : '-=40')}); 
}); 

http://www.adomas.org/javascript-mouse-wheel/

+3

爲什麼在我的瀏覽器中,Ubuntu上的Firefox和Chrome都需要使用它來使其工作:('''''''''''' originalEvent.detail' – Kannika 2014-02-05 12:00:22