您的位置:首页 > 其它

子元素滚动不影响父元素

2016-02-10 19:26 281 查看
原文链接:https://www.geek-share.com/detail/2666103560.html

Javascript

$.fn.scrollUnique = function() {
return $(this).each(function() {
var eventType = 'mousewheel';
// 火狐是DOMMouseScroll事件
if (document.mozHidden !== undefined) {
eventType = 'DOMMouseScroll';
}
$(this).on(eventType, function(event) {
// 一些数据
var scrollTop = this.scrollTop,
scrollHeight = this.scrollHeight,
height = this.clientHeight;

var delta = (event.originalEvent.wheelDelta) ? event.originalEvent.wheelDelta : -(event.originalEvent.detail || 0);

if ((delta > 0 && scrollTop <= delta) || (delta < 0 && scrollHeight - height - scrollTop <= -1 * delta)) {
// IE浏览器下滚动会跨越边界直接影响父级滚动,因此,临界时候手动边界滚动定位
this.scrollTop = delta > 0? 0: scrollHeight;
// 向上滚 || 向下滚
event.preventDefault();
}
});
});
};

$(".inner").scrollUnique();

 

HTML

<div class="outer">
<div class="inner">
<div class="inner1"></div>
</div>
</div>

 

CSS

.outer {
height: 2000px;
border: 1px solid red;
}
.inner {
border: 1px solid red;
width: 300px;
height: 300px;
overflow-y: auto;
}
.inner1 {
border: 1px solid blue;
width: 300px;
height: 500px;
}

 

转载于:https://www.cnblogs.com/sunhk/p/5186072.html

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: