Я хочу получить положение элемента относительно окна просмотра браузера (окна просмотра, в котором отображается страница, а не всей страницы). Как это можно сделать в JavaScript?
Большое спасибо
Я хочу получить положение элемента относительно окна просмотра браузера (окна просмотра, в котором отображается страница, а не всей страницы). Как это можно сделать в JavaScript?
Большое спасибо
Существующие ответы теперь устарели. Нативный метод getBoundingClientRect()
существует уже довольно давно и делает то, о чем спрашивает этот вопрос. Кроме того, он поддерживается во всех браузерах (включая IE 5, кажется!)
От Страница MDN:
Возвращаемое значение - это объект TextRectangle, который содержит свойства слева, сверху, справа и снизу, описывающие рамку в пикселях, с верхним левым относительно левого верхнего угла окна просмотра.
Вы используете его так:
var viewportOffset = el.getBoundingClientRect();
// these are relative to the viewport, i.e. the window
var top = viewportOffset.top;
var left = viewportOffset.left;
В моем случае, просто чтобы быть уверенным в прокрутке, я добавил окно. Прокрутите до уравнения:
var element = document.getElementById('myElement');
var topPos = element.getBoundingClientRect().top + window.scrollY;
var leftPos = element.getBoundingClientRect().left + window.scrollX;
Это позволяет мне получить реальное относительное положение элемента на документе, даже если оно было прокручено.
Изменить: Добавить код для учета прокрутки страницы.
function findPos(id) {
var node = document.getElementById(id);
var curtop = 0;
var curtopscroll = 0;
if (node.offsetParent) {
do {
curtop += node.offsetTop;
curtopscroll += node.offsetParent ? node.offsetParent.scrollTop : 0;
} while (node = node.offsetParent);
alert(curtop - curtopscroll);
}
}
Аргумент id - это идентификатор элемента, смещение которого вы хотите. Адаптировано из сообщения quirksmode.
Вы можете попробовать:
node.offsetTop - window.scrollY
Он работает с Opera с определенным метатегью просмотра.
var element = document.querySelector('selector');
var bodyRect = document.body.getBoundingClientRect(),
elemRect = element.getBoundingClientRect(),
offset = elemRect.top - bodyRect.top;
JQuery реализует это довольно элегантно. Если вы посмотрите на источник offset
jQuery, вы обнаружите, что в основном это так:
var rect = elem.getBoundingClientRect();
var win = elem.ownerDocument.defaultView;
return {
top: rect.top + win.pageYOffset,
left: rect.left + win.pageXOffset
};
Функция эта страница вернет прямоугольник с координатами верхнего, левого, вертикального и поперечного элементов передаваемого элемента относительно порт просмотра браузера.
localToGlobal: function( _el ) {
var target = _el,
target_width = target.offsetWidth,
target_height = target.offsetHeight,
target_left = target.offsetLeft,
target_top = target.offsetTop,
gleft = 0,
gtop = 0,
rect = {};
var moonwalk = function( _parent ) {
if (!!_parent) {
gleft += _parent.offsetLeft;
gtop += _parent.offsetTop;
moonwalk( _parent.offsetParent );
} else {
return rect = {
top: target.offsetTop + gtop,
left: target.offsetLeft + gleft,
bottom: (target.offsetTop + gtop) + target_height,
right: (target.offsetLeft + gleft) + target_width
};
}
};
moonwalk( target.offsetParent );
return rect;
}
Я предполагаю, что на веб-странице существует элемент с идентификатором btn1
, а также включен jQuery. Это работало во всех современных браузерах Chrome, FireFox, IE >= 9 и Edge.
jQuery используется только для определения позиции относительно документа.
var screenRelativeTop = $("#btn1").offset().top - (window.scrollY ||
window.pageYOffset || document.body.scrollTop);
var screenRelativeLeft = $("#btn1").offset().left - (window.scrollX ||
window.pageXOffset || document.body.scrollLeft);
Спасибо за все ответы. Кажется, у Prototype уже есть функция, которая делает это (функция page()). Просмотрев исходный код функции, я обнаружил, что он сначала вычисляет позицию смещения элемента относительно страницы (то есть вершину документа), а затем вычитает scrollTop из этого. Подробнее см. Исходный код прототипа.
Иногда значение свойства объекта getBoundingClientRect()
показывает 0 для IE. В этом случае вы должны установить display = 'block'
для элемента. Вы можете использовать код ниже для всех браузеров, чтобы получить смещение.
Расширить функциональность jQuery:
(function($) {
jQuery.fn.weOffset = function () {
var de = document.documentElement;
$(this).css("display", "block");
var box = $(this).get(0).getBoundingClientRect();
var top = box.top + window.pageYOffset - de.clientTop;
var left = box.left + window.pageXOffset - de.clientLeft;
return { top: top, left: left };
};
}(jQuery));
Используйте:
var elementOffset = $("#" + elementId).weOffset();