html js滚轮事件,Js滚轮事件

鼠标滚轮

IE/Chrome : onmousewheel

event :wheelDelta 数字类型

滚轮往上走就是:120

滚轮往下走就是-120

标准下面event.detail永远都是0,非标准IE的event.detail都是undefined

ff: DOMMouseScroll 必须用addEventListener来实现绑定

evnet.detail

滚轮往上走:就是-3

滚轮往下走:就是3

用addEventListener绑定的事件需要通过event下面的preventDefault()来阻止默认行为

IE下面用attachEvent来绑定的话,还是可以用return false来阻止默认事件

无标题文档

#div1 {width: 100px; height: 100px; background: red;}

/*

鼠标滚轮事件

*/

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;

}

}

封装成插件

/*

鼠标滚轮事件

*/

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;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值