今天要分享的是运用原生JS滚动鼠标改变元素大小,效果如下:
以下是代码实现,欢迎大家复制粘贴 。
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>原原生JS滚动鼠标改变元素大小</title>
<style>
#div1 {
width: 200px;
height: 200px;
background: red;
position: relative;
left:200px;
top:200px;
}
</style>
<script>
//普通事件:onclick、onmousedown
//DOM事件:DOMMouseScroll
//DOM事件只能通过绑定来添加
function myAddEvent(obj, sEvent, fn) {
if (obj.attachEvent) {
obj.attachEvent('on' + sEvent, fn);
} else {
obj.addEventListener(sEvent, fn, false);
}
}
window.onload = function () {
var oDiv = document.getElementById('div1');
// 滚动事件
function onMouseWheel(ev) {
var oEvent = ev || event;
var bDown = true;
// 用于区分是向上滚动还是向下滚动
bDown = oEvent.wheelDelta ? oEvent.wheelDelta < 0 : oEvent.detail > 0;
if (bDown) {
oDiv.style.height = oDiv.offsetHeight + 10 + 'px';
} else {
oDiv.style.height = oDiv.offsetHeight - 10 + 'px';
};
if (oEvent.preventDefault) {
oEvent.preventDefault();
};
return false;
};
myAddEvent(oDiv, 'mousewheel', onMouseWheel);
myAddEvent(oDiv, 'DOMMouseScroll', onMouseWheel);
};
</script>
</head>
<body style="height:2000px;">
<div id="div1"></div>
</body>
</html>