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

获取浏览器窗口的可视区域高度和宽度,滚动条高度有需要的朋友可参考一下。

IE中,浏览器显示窗口大小只能以下获取: 代码如下

document.body.offsetWidth;
document.body.offsetHeight;

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

document.documentElement.clientWidth; 
document.documentElement.clientHeight;

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

windows.innerWidth;
windows.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(windows.innerWidth){
		return {
			width : windows.innerWidth,
			height: windows.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()); //获取滚动条到左边的垂直宽度



转自 http://blog.sina.com.cn/s/blog_70a3539f0101ayv8.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值