NoO*_*lse 44 html javascript scroll
我有一个搜索输入文本,我想focus()在加载页面时应用一个,问题是该focus函数自动滚动到这个字段.任何禁用此滚动的解决方案?
<input id="search_terms" type="text" />
<script>
document.getelementbyId('search-terms').focus();
</script>
Run Code Online (Sandbox Code Playgroud)
pet*_*est 46
这是一个完整的解决方案:
var cursorFocus = function(elem) {
var x = window.scrollX, y = window.scrollY;
elem.focus();
window.scrollTo(x, y);
}
cursorFocus(document.getElementById('search-terms'));
Run Code Online (Sandbox Code Playgroud)
Jos*_*osh 41
有一个新的WHATWG标准,它允许您传递一个对象focus(),指定您希望阻止浏览器将元素滚动到视图中:
const element = document.getElementById('search-terms')
element.focus({
preventScroll: true
});
Run Code Online (Sandbox Code Playgroud)
Chrome 64和Edge Insider Preview build 17046目前支持它.
如果您使用的是jQuery,您也可以这样做:
$.fn.focusWithoutScrolling = function(){
var x = window.scrollX, y = window.scrollY;
this.focus();
window.scrollTo(x, y);
};
Run Code Online (Sandbox Code Playgroud)
然后
$('#search_terms').focusWithoutScrolling();
Run Code Online (Sandbox Code Playgroud)
一个支持更多浏览器的修改版本(包括IE9)
var cursorFocus = function(elem) {
var x, y;
// More sources for scroll x, y offset.
if (typeof(window.pageXOffset) !== 'undefined') {
x = window.pageXOffset;
y = window.pageYOffset;
} else if (typeof(window.scrollX) !== 'undefined') {
x = window.scrollX;
y = window.scrollY;
} else if (document.documentElement && typeof(document.documentElement.scrollLeft) !== 'undefined') {
x = document.documentElement.scrollLeft;
y = document.documentElement.scrollTop;
} else {
x = document.body.scrollLeft;
y = document.body.scrollTop;
}
elem.focus();
if (typeof x !== 'undefined') {
// In some cases IE9 does not seem to catch instant scrollTo request.
setTimeout(function() { window.scrollTo(x, y); }, 100);
}
}
Run Code Online (Sandbox Code Playgroud)
这里的答案不是在整个层次结构上滚动,而是仅在主滚动条上滚动.这个答案将照顾一切:
var focusWithoutScrolling = function (el) {
var scrollHierarchy = [];
var parent = el.parentNode;
while (parent) {
scrollHierarchy.push([parent, parent.scrollLeft, parent.scrollTop]);
parent = parent.parentNode;
}
el.focus();
scrollHierarchy.forEach(function (item) {
var el = item[0];
// Check first to avoid triggering unnecessary `scroll` events
if (el.scrollLeft != item[1])
el.scrollLeft = item[1];
if (el.scrollTop != item[2])
el.scrollTop = item[2];
});
};
Run Code Online (Sandbox Code Playgroud)