gpt4 book ai didi

javascript - 如何以像素为单位计算工具栏、地址栏和其他导航工具的高度?

转载 作者:可可西里 更新时间:2023-11-01 02:52:36 24 4
gpt4 key购买 nike

基本上我需要知道 y 轴距离屏幕左上角多少个像素,直到我到达实际的网络窗口。有没有人有任何想法...?

最佳答案

我不知道如何返回外部组件的高度,但我从 http://www.alexandre-gomes.com/?p=115 中获取了这个并对其进行调整以返回滚动条高度。

测试在以下浏览器中工作:

  • Chrome
  • FF 9+
  • IE9 (谢谢 Pax0r)
  • Opera (谢谢 Pax0r)

如果有人可以在其他浏览器中测试它并给我反馈,我会相应地修改这个答案。

使用 JQuery :

jQuery.getScrollBarSize = function() {
var inner = $('<p></p>').css({
'width':'100%',
'height':'100%'
});
var outer = $('<div></div>').css({
'position':'absolute',
'width':'100px',
'height':'100px',
'top':'0',
'left':'0',
'visibility':'hidden',
'overflow':'hidden'
}).append(inner);

$(document.body).append(outer);

var w1 = inner.width(), h1 = inner.height();
outer.css('overflow','scroll');
var w2 = inner.width(), h2 = inner.height();
if (w1 == w2 && outer[0].clientWidth) {
w2 = outer[0].clientWidth;
}
if (h1 == h2 && outer[0].clientHeight) {
h2 = outer[0].clientHeight;
}

outer.detach();

return [(w1 - w2),(h1 - h2)];
};

alert( $.getScrollBarSize() ); // in Chrome = [15,15] in FF = [16,16]

没有 JQuery

function getScrollBarSize () {  
var inner = document.createElement('p');
inner.style.width = "100%";
inner.style.height = "100%";

var outer = document.createElement('div');
outer.style.position = "absolute";
outer.style.top = "0px";
outer.style.left = "0px";
outer.style.visibility = "hidden";
outer.style.width = "100px";
outer.style.height = "100px";
outer.style.overflow = "hidden";
outer.appendChild (inner);

document.body.appendChild (outer);

var w1 = inner.offsetWidth;
var h1 = inner.offsetHeight;
outer.style.overflow = 'scroll';
var w2 = inner.offsetWidth;
var h2 = inner.offsetHeight;
if (w1 == w2) w2 = outer.clientWidth;
if (h1 == h2) h2 = outer.clientHeight;

document.body.removeChild (outer);

return [(w1 - w2),(h1 - h2)];
};

关于javascript - 如何以像素为单位计算工具栏、地址栏和其他导航工具的高度?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3417139/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com