zl程序教程

您现在的位置是:首页 >  前端

当前栏目

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

JSjQuery浏览器代码 实现 获取 以及 窗口
2023-06-13 09:14:42 时间
获取浏览器窗口的可视区域高度和宽度,滚动条高度有需要的朋友可参考一下。
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

总结一下实例
复制代码代码如下:
functiongetViewSizeWithoutScrollbar(){//不包含滚动条
return{
width:document.documentElement.clientWidth,
height:document.documentElement.clientHeight
}
}
functiongetViewSizeWithScrollbar(){//包含滚动条
if(window.innerWidth){
return{
width:window.innerWidth,
height:window.innerHeight
}
}elseif(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的总高度包括borderpaddingmargin
alert($(window).width());//浏览器时下窗口可视区域宽度
alert($(document).width());//浏览器时下窗口文档对于象宽度
alert($(document.body).width());//浏览器时下窗口文档body的高度
alert($(document.body).outerWidth(true));//浏览器时下窗口文档body的总宽度包括borderpaddingmargin

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