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 动态添加样式规则 W3C校检
Dec 25 Javascript
JavaScript学习历程和心得小结
Aug 16 Javascript
javascript权威指南 学习笔记之javascript数据类型
Sep 24 Javascript
javascript 判断整数方法分享
Dec 16 Javascript
javascript中返回顶部按钮的实现
May 05 Javascript
Angular.JS学习之依赖注入$injector详析
Oct 20 Javascript
layui点击导航栏刷新tab页的示例代码
Aug 14 Javascript
前端Electron新手入门教程详解
Jun 21 Javascript
浅析Angular 实现一个repeat指令的方法
Jul 21 Javascript
vue计算属性+vue中class与style绑定(推荐)
Mar 30 Javascript
ant design vue datepicker日期选择器中文化操作
Oct 28 Javascript
vue点击Dashboard不同内容 跳转到同一表格的实例
Nov 13 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的存储过程的实现代码
2008/08/12 PHP
PHP实现链式操作的三种方法详解
2017/11/16 PHP
PHP仿tp实现mvc框架基本设计思路与实现方法分析
2018/05/23 PHP
PDO::errorInfo讲解
2019/01/28 PHP
php实现微信分享朋友链接功能
2019/02/18 PHP
关于恒等于(===)和非恒等于(!==)
2007/08/20 Javascript
推荐一些非常不错的javascript学习资源站点
2007/08/29 Javascript
用原生JavaScript实现jQuery的$.getJSON的解决方法
2013/05/03 Javascript
jquery等待效果示例
2014/05/01 Javascript
jquery序列化方法实例分析
2015/06/10 Javascript
js实现无缝滚动图
2017/02/22 Javascript
微信小程序开发教程之增加mixin扩展
2017/08/09 Javascript
jQuery:unbind方法的使用详解
2017/08/14 jQuery
JS简单实现父子窗口传值功能示例【未使用iframe框架】
2017/09/20 Javascript
Node.js微信 access_token ( jsapi_ticket ) 存取与刷新的示例
2017/09/30 Javascript
安装Node.js并启动本地服务的操作教程
2018/05/12 Javascript
jquery.onoff实现简单的开关按钮功能(推荐)
2018/05/24 jQuery
vue.js内置组件之keep-alive组件使用
2018/07/10 Javascript
详解vue组件中使用路由方法
2019/02/12 Javascript
基于Vue el-autocomplete 实现类似百度搜索框功能
2019/10/25 Javascript
Python sys.path详细介绍
2013/10/17 Python
bluepy 一款python封装的BLE利器简单介绍
2019/06/25 Python
python multiprocessing模块用法及原理介绍
2019/08/20 Python
python 中Arduino串口传输数据到电脑并保存至excel表格
2019/10/14 Python
Python使用graphviz画流程图过程解析
2020/03/31 Python
Python如何获取文件路径/目录
2020/09/22 Python
使用html2canvas实现将html内容写入到canvas中生成图片
2020/01/03 HTML / CSS
关于canvas.toDataURL 在iOS运行失败的问题解决
2020/09/16 HTML / CSS
Sam’s Club山姆会员商店:沃尔玛旗下高端会员制商店
2017/01/16 全球购物
澳洲国民品牌乡村路折扣店:Country Road & Trenery Outlet
2018/04/19 全球购物
美国渔具店:FishUSA
2019/08/07 全球购物
上班看电影检讨书
2014/02/12 职场文书
工艺工程师岗位职责
2014/03/04 职场文书
2014年教师节演讲稿
2014/09/03 职场文书
2014年有孩子的离婚协议书范本
2014/10/08 职场文书
隐形的翅膀观后感
2015/06/10 职场文书