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


Posted in Javascript onDecember 17, 2012

获取浏览器窗口的可视区域高度和宽度,滚动条高度有需要的朋友可参考一下。
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()); //获取滚动条到左边的垂直宽度

Javascript 相关文章推荐
javascript call和apply方法
Nov 24 Javascript
JS模块与命名空间的介绍
Mar 22 Javascript
控制文字内容的显示与隐藏示例
Jun 11 Javascript
js使用正则实现ReplaceAll全部替换的方法
Aug 22 Javascript
原生的html元素选择器类似jquery选择器
Oct 15 Javascript
jQuery+ajax+asp.net获取Json值的方法
Jun 08 Javascript
javascript设计模式Constructor(构造器)模式
Aug 19 Javascript
jQuery实现鼠标经过时高亮,同时其他同级元素变暗的效果
Sep 18 Javascript
Bootstrap table使用方法详细介绍
Dec 09 Javascript
vue+socket.io+express+mongodb 实现简易多房间在线群聊示例
Oct 21 Javascript
redux中间件之redux-thunk的具体使用
Apr 17 Javascript
vue 强制组件重新渲染(重置)的两种方案
Oct 29 Javascript
jQuery获取样式中的背景颜色属性值/颜色值
Dec 17 #Javascript
IE不支持getElementsByClassName最终完美解决方案
Dec 17 #Javascript
jQuery移动和复制dom节点实用DOM操作案例
Dec 17 #Javascript
javascript中判断一个值是否在数组中并没有直接使用
Dec 17 #Javascript
firefox下jquery iframe刷新页面提示会导致重复之前动作
Dec 17 #Javascript
使用按钮控制以何种方式打开新窗口的属性介绍
Dec 17 #Javascript
如何让页面在打开时自动刷新一次让图片全部显示
Dec 17 #Javascript
You might like
php+mysql事务rollback&amp;commit示例
2010/02/08 PHP
初品cakephp 入门基础
2012/02/16 PHP
php模板函数 正则实现代码
2012/10/15 PHP
PHP对文件进行加锁、解锁实例
2015/01/23 PHP
php中get_defined_constants函数用法实例分析
2015/05/12 PHP
如何使用PHP给图片加水印
2016/10/12 PHP
thinkphp3.2.0 setInc方法 源码全面解析
2018/01/29 PHP
PHP通过调用新浪API生成t.cn格式短网址链接的方法详解
2019/02/20 PHP
PHP二维数组分页2种实现方法解析
2020/07/09 PHP
jQuery getJSON()+.ashx 实现分页(改进版)
2013/03/28 Javascript
使用jQuery时Form表单元素ID和name命名大忌
2014/03/06 Javascript
node.js中的emitter.on方法使用说明
2014/12/10 Javascript
jQuery中:contains选择器用法实例
2014/12/30 Javascript
js实现随机抽选效果、随机抽选红色球效果
2017/01/13 Javascript
JavaScript实现的原生态兼容IE6可调可控滚动文字功能详解
2017/09/19 Javascript
jQueryMobile之窗体长内容的缺陷与解决方法实例分析
2017/09/20 jQuery
详解微信小程序的 request 封装示例
2018/08/21 Javascript
vue 优化CDN加速的方法示例
2018/09/19 Javascript
JS函数参数的传递与同名参数实例分析
2020/03/16 Javascript
关于vue的列表图片选中打钩操作
2020/09/09 Javascript
Saltstack快速入门简单汇总
2016/03/01 Python
Python MD5加密实例详解
2017/08/02 Python
详解Python中where()函数的用法
2018/03/27 Python
python实现任意位置文件分割的实例
2018/12/14 Python
Python pandas DataFrame操作的实现代码
2019/06/21 Python
windows下python虚拟环境virtualenv安装和使用详解
2019/07/16 Python
Python matplotlib绘制饼状图功能示例
2019/09/10 Python
日本索尼音乐商店:Sony Music Shop
2018/07/17 全球购物
2013年军训通讯稿
2014/02/05 职场文书
优秀教师演讲稿
2014/05/06 职场文书
幼儿园优秀班主任事迹材料
2014/05/14 职场文书
房屋所有权证明
2014/10/20 职场文书
Python带你从浅入深探究Tuple(基础篇)
2021/05/15 Python
比较几种Redis集群方案
2021/06/21 Redis
Java界面编程实现界面跳转
2022/06/16 Java/Android