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来确定。
这篇关于如何准确确定元素是否可滚动?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:如何准确确定元素是否可滚动?
基础教程推荐
- Fabric JS绘制具有活动形状的多边形 2022-01-01
- 原生拖动事件后如何获取 mouseup 事件? 2022-01-01
- 即使用户允许,Gmail 也会隐藏外部电子邮件图片 2022-01-01
- Bootstrap 模态出现在背景下 2022-01-01
- 检查 HTML5 拖放文件类型 2022-01-01
- 如何添加到目前为止的天数? 2022-01-01
- fetch 是否支持原生多文件上传? 2022-01-01
- 在 contenteditable 中精确拖放 2022-01-01
- Bokeh Div文本对齐 2022-01-01
- npm start 错误与 create-react-app 2022-01-01
