基本上我需要知道y轴距离屏幕左上角有多少像素,直到我到达实际的Web窗口.有没有人有任何想法......?
Yan*_*hon 14
我不知道如何返回外部组件的高度,但我从http://www.alexandre-gomes.com/?p=115获取并调整它以返回滚动条高度.
如果有人可以在其他浏览器中测试它并给我反馈,我会相应地修改这个答案.
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]
Run Code Online (Sandbox Code Playgroud)
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)];
};
Run Code Online (Sandbox Code Playgroud)
不幸的是,我认为没有办法在所有浏览器中实现这一点.Chrome,Firefox,Safari和Opera都支持window.innerHeight和window.outerHeight,因此在这些浏览器中,假设您没有在框架内执行代码,那么就是这样的情况:
var chromeH = window.innerHeight - window.outerHeight;
Run Code Online (Sandbox Code Playgroud)
留下(你猜对了)Internet Explorer,它不支持这两个属性.它甚至不在IE9 PP3中. 为了公平对待IE,他们没有在DOM规范中定义公平性,它们在w3c CSSOM工作草案中定义.有一个"解决方案" 1涉及调整窗口大小并再次调整大小,但它会导致窗口闪烁,并且无法使用选项卡式窗口.
1(滚动到第二个示例)
| 归档时间: |
|
| 查看次数: |
20600 次 |
| 最近记录: |