How to accurately determine if an element is scrollable?(如何准确确定元素是否可滚动?)
问题描述
我正在处理一个定制的挖空绑定,它确定是否正在滚动特定元素,并使用该元素相对于视区的顶部来更新绑定可观测对象。目前,绑定似乎起作用了,但我担心是否在某些情况下它不起作用。
HTML:
Scroll position: <span data-bind="text: scrollPosition"></span>
<div class="longdiv">
<p data-bind="scroll: scrollPosition">This is some text.</p>
<div class="shim"></div>
</div>
css:
.longdiv {
width: 200px;
height: 200px;
overflow: scroll;
border: 1px solid black;
}
JS:
ko.bindingHandlers.scroll = {
init: function(element, valueAccessor, allBindings, viewModel, bindingContext) {
var firstScrollableContainer = null;
var binding = allBindings.get('scroll');
$(element).parents().each(function (i, parent) {
if ($(parent).css('overflow')=='scroll') {
firstScrollableContainer = parent;
return false;
}
});
firstScrollableContainer = firstScrollableContainer || window;
binding(element.getBoundingClientRect().top);
$(firstScrollableContainer).scroll(function() {
binding(element.getBoundingClientRect().top);
});
}
};
var ViewModel = function() {
var self = this;
self.scrollPosition = ko.observable(0);
};
ko.applyBindings(new ViewModel());
JSFiddle
绑定获取元素并使用jQuery遍历父链,查看父元素是否有溢出:滚动集。如果它找到一个带有overflow:scroll的div,它会将一个事件处理程序绑定到该元素的scroll事件。如果它没有找到具有overflow:scroll的父级,则会绑定到窗口的scroll事件。
给出一个结构如下的文档,我要找的就是:
body > div > div > div > p
是最接近p的可以滚动的包含元素,因此我可以将事件处理程序附加到它。
我的问题是:查看Overflow:Scroll是否足以测试父元素是否可以滚动?如果不是,我应该看什么?编辑:根据您的有用意见和答案,以下是我提出的解决方案:
function scrollable(element) {
var vertically_scrollable, horizontally_scrollable;
var e = $(element);
if ( e.css('overflow') == 'scroll'
|| e.css('overflow') == 'auto'
|| e.css('overflowY') == 'scroll'
|| e.css('overflowY') == 'auto'
|| e.css('height') != 'none'
|| e.css('max-height') != 'none'
) {
return true;
} else {
return false;
}
}
推荐答案
您想知道元素是可以滚动还是当前可以滚动?
元素可以滚动吗?
如果元素具有固定的height
(或max-height
)且overflow-y
为scroll
或auto
,则可以滚动。但由于tell if an element's height is fixed or not不容易,所以只勾选overflow-y
:
e.css('overflow-y') == 'scroll' || e.css('overflow-y') == 'auto'
元素现在可以滚动吗?
如果元素的scrollHeight
大于元素的clientHeight
,并且元素具有滚动条,则元素现在可以立即滚动,这可以通过比较clientWidth
和offsetWidth
(考虑边距和边框)或检查overflow-y
是scroll
还是auto
来确定。
这篇关于如何准确确定元素是否可滚动?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何准确确定元素是否可滚动?
基础教程推荐
- 在 JS 中获取客户端时区(不是 GMT 偏移量) 2022-01-01
- 有没有办法使用OpenLayers更改OpenStreetMap中某些要素 2022-09-06
- 悬停时滑动输入并停留几秒钟 2022-01-01
- 动态更新多个选择框 2022-01-01
- Karma-Jasmine:如何正确监视 Modal? 2022-01-01
- 当用户滚动离开时如何暂停 youtube 嵌入 2022-01-01
- 我什么时候应该在导入时使用方括号 2022-01-01
- 在for循环中使用setTimeout 2022-01-01
- 响应更改 div 大小保持纵横比 2022-01-01
- 角度Apollo设置WatchQuery结果为可用变量 2022-01-01