子元素滚动不影响父元素
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
相关文章推荐
- 子元素滚动不影响父元素
- 解决子元素滚动影响父元素的JS
- 随滚动条滚动,动态修改元素class
- iPhone mobile safari fixed 元素滚动慢的问题处理
- css设置透明度不影响子元素
- js监听滚动条滚动 改变元素
- margin-top会影响父元素
- 【脚本化文档】——文档和元素的几何形状和滚动
- 文本滚动元素 marquee 研究报告
- 子元素不受父元素的透明度影响
- 个人关于css中几种取消浮动对于其他元素影响的见解
- 滚动锚定(Scroll Anchoring)- 让视口内容不再因视口上方 DOM 元素的高度变化而产生跳动
- ios系统fixed定位元素滚动后无法点击
- 文本滚动元素 marquee 研究报告
- 当元素滚动到顶部后固定位置
- jQuery和CSS3炫酷滚动页面内容元素动画特效
- 嵌套盒元素子元素margin-top影响父元素
- jQuery页面滚动元素进入视口发生动画特效插件
- 清除元素浮动带来的影响
- 阻止事件冒泡,嵌套元素事件加载互不影响