鼠標滾輪
IE/Chrome : onmousewheel
event :wheelDelta 數字類型
滾輪往上走就是:120
滾輪往下走就是-120
標準下面event.detail永遠都是0,非標準IE的event.detail都是undefined
ff: DOMMouseScroll 必須用addEventListener來實現綁定
evnet.detail
滾輪往上走:就是-3
滾輪往下走:就是3return false阻止的是obj.on事件名稱=fn所觸發的默認行為,阻止不了addEventListener綁定行為
用addEventListener綁定的事件需要通過event下面的preventDefault()來阻止默認行為
IE下面用attachEvent來綁定的話,還是可以用return false來阻止默認事件
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>無標題文檔</title>
<style>
#div1 {width: 100px; height: 100px; background: red;}
</style>
<script>
/*
鼠標滾輪事件
*/
window.onload = function() {
var oDiv = document.getElementById('div1');
/*
ie/chrome : onmousewheel
event.wheelDelta
上:120
下:-120
firefox : DOMMouseScroll 必須用addEventListener
event.detail
上:-3
下:3
return false阻止的是 obj.on事件名稱=fn 所觸發的默認行為
addEventListener綁定的事件需要通過event下面的preventDefault();
*/
oDiv.onmousewheel = fn;
if (oDiv.addEventListener) {
oDiv.addEventListener('DOMMouseScroll', fn, false);
}
function fn(ev) {
var ev = ev || event;
var b = true;
if (ev.wheelDelta) {
b = ev.wheelDelta > 0 ? true : false;
} else {
b = ev.detail < 0 ? true : false;
}
if ( b ) {
this.style.height = this.offsetHeight - 10 + 'px';
} else {
this.style.height = this.offsetHeight + 10 + 'px';
}
if (ev.preventDefault) {
ev.preventDefault();
}
return false;
}
}
</script>
</head>
<body style="height: 2000px;">
<div id="div1"></div>
</body>
</html>
封裝成插件
<script>
/*
鼠標滾輪事件
*/
mousewheel(document.getElementById("div1"),function(){console.log("向下滾")},function(){console.log("向上滾")});
function mousewheel(obj,downfn,upfn)
{
obj.onmousewheel = fn;
if (obj.addEventListener) {
obj.addEventListener('DOMMouseScroll', fn, false);
}
function fn(ev) {
var ev = ev || event;
var b = true;
if (ev.wheelDelta) {
b = ev.wheelDelta > 0 ? true : false;
} else {
b = ev.detail < 0 ? true : false;
}
if(b) {
upfn&&upfn();
} else {
downfn&&downfn();
}
if (ev.preventDefault) {
ev.preventDefault();
}
return false;
}
}
</script>