欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

js/jquery获取浏览器窗口可视区域高度和宽度以及滚动条高度实现代码

程序员文章站 2022-07-05 15:47:09
获取窗口的可视区域高度和宽度,滚动条高度有需要的朋友可参考一下。 ie中,浏览器显示窗口大小只能以下获取: 代码如下. 代码如下: document.body.offse...

获取窗口的可视区域高度和宽度,滚动条高度有需要的朋友可参考一下。
ie中,浏览器显示窗口大小只能以下获取: 代码如下.

代码如下:


document.body.offsetwidth
document.body.offsetheight


在声明了doctype的浏览器中,可以用以下来获取浏览器显示窗口大小: 代码如下.

代码如下:


document.documentelement.clientwidth
document.documentelement.clientheight


ie,ff,safari皆支持该方法,opera虽支持该属性,但是返回的是页面尺寸;
同时,除了ie以外的所有浏览器都将此信息保存在window对象中,可以用以下获取: 代码如下.

代码如下:


window.innerwidth
window.innerheight


整个网页尺寸一般获得方法 代码如下.

. 代码如下:


document.body.scrollwidth
document.body.scrollheight


屏幕分辨率高度一般获得方法 代码如下.

. 代码如下:


window.screen.height
window.screen.width


总结一下实例

. 代码如下:


function getviewsizewithoutscrollbar(){//不包含滚动条
return {
width : document.documentelement.clientwidth,
height: document.documentelement.clientheight
}
}
function getviewsizewithscrollbar(){//包含滚动条
if(window.innerwidth){
return {
width : window.innerwidth,
height: window.innerheight
}
}else if(document.documentelement.offsetwidth == document.documentelement.clientwidth){
return {
width : document.documentelement.offsetwidth,
height: document.documentelement.offsetheight
}
}else{
return {
width : document.documentelement.clientwidth + getscrollwith(),
height: document.documentelement.clientheight + getscrollwith()
}
}
}


ie,firefox 差异如下:
ie6.0、ff1.06+:

. 代码如下:


clientwidth = width + padding
clientheight = height + padding
offsetwidth = width + padding + border
offsetheight = height + padding + border
ie5.0/5.5:
clientwidth = width - border
clientheight = height - border
offsetwidth = width
offsetheight = height


另附个人最常用的获取整页宽高的方法(需要jquery框架) 代码如下.

. 代码如下:


$(document).width() < $('body').width() ? $(document).width() : $('body').width();
$(document).height() < $('body').height() ? $(document).height() : $('body').height();


alert($(window).height()); //浏览器时下窗口可视区域高度
alert($(document).height()); //浏览器时下窗口文档的高度
alert($(document.body).height());//浏览器时下窗口文档body的高度
alert($(document.body).outerheight(true));//浏览器时下窗口文档body的总高度 包括border padding margin
alert($(window).width()); //浏览器时下窗口可视区域宽度
alert($(document).width());//浏览器时下窗口文档对于象宽度
alert($(document.body).width());//浏览器时下窗口文档body的高度
alert($(document.body).outerwidth(true));//浏览器时下窗口文档body的总宽度 包括border padding margin

alert($(document).scrolltop()); //获取滚动条到顶部的垂直高度
alert($(document).scrollleft()); //获取滚动条到左边的垂直宽度