js获取浏览器基本信息大全


Posted in Javascript onNovember 27, 2014

网页可见区域宽:document.body.clientWidth
网页可见区域高:document.body.clientHeight
网页可见区域宽:document.body.offsetWidth (包括边线的宽)
网页可见区域高:document.body.offsetHeight (包括边线的宽)
网页正文全文宽:document.body.scrollWidth
网页正文全文高:document.body.scrollHeight
网页被卷去的高:document.body.scrollTop
网页被卷去的左:document.body.scrollLeft
网页正文部分上:window.screenTop
网页正文部分左:window.screenLeft
屏幕分辨率的高:window.screen.height
屏幕分辨率的宽:window.screen.width
屏幕可用工作区高度:window.screen.availHeight
屏幕可用工作区宽度:window.screen.availWidth

HTML精确定位:scrollLeft,scrollWidth,clientWidth,offsetWidth
scrollHeight: 获取对象的滚动高度。
scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距离
scrollTop:设置或获取位于对象最顶端和窗口中可见内容的最顶端之间的距离
scrollWidth:获取对象的滚动宽度
offsetHeight:获取对象相对于版面或由父坐标 offsetParent 属性指定的父坐标的高度
offsetLeft:获取对象相对于版面或由 offsetParent 属性指定的父坐标的计算左侧位置
offsetTop:获取对象相对于版面或由 offsetTop 属性指定的父坐标的计算顶端位置
event.clientX 相对文档的水平座标
event.clientY 相对文档的垂直座标
event.offsetX 相对容器的水平坐标
event.offsetY 相对容器的垂直坐标
document.documentElement.scrollTop 垂直方向滚动的值
event.clientX+document.documentElement.scrollTop 相对文档的水平座标+垂直方向滚动的量

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

(需要提一下:CSS中的margin属性,与clientWidth、offsetWidth、clientHeight、offsetHeight均无关)

-------------------

技术要点

本节代码主要使用了Document对象关于窗口的一些属性,这些属性的主要功能和用法如下。

要得到窗口的尺寸,对于不同的浏览器,需要使用不同的属性和方法:若要检测窗口的真实尺寸,在Netscape下需要使用Window的属性;在 IE下需要深入Document内部对body进行检测;在DOM环境下,若要得到窗口的尺寸,需要注意根元素的尺寸,而不是元素。

Window对象的innerWidth属性包含当前窗口的内部宽度。Window对象的innerHeight属性包含当前窗口的内部高度。

Document对象的body属性对应HTML文档的标签。Document对象的documentElement属性则表示HTML文档的根节点。

document.body.clientHeight表示HTML文档所在窗口的当前高度。document.body. clientWidth表示HTML文档所在窗口的当前宽度。

关于获取各种浏览器可见窗口大小的一点点研究。

在我本地测试当中:在IE、FireFox、Opera下都可以使用

document.body.clientWidth

document.body.clientHeight即可获得,很简单,很方便。

而在公司项目当中:Opera仍然使用

document.body.clientWidth

document.body.clientHeight

可是IE和FireFox则使用

document.documentElement.clientWidth

document.documentElement.clientHeight

原来是W3C的标准在作怪啊http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

如果在页面中添加这行标记的话

在IE中:document.body.clientWidth ==> BODY对象宽度

document.body.clientHeight ==> BODY对象高度

document.documentElement.clientWidth ==> 可见区域宽度

document.documentElement.clientHeight ==> 可见区域高度

在FireFox中:document.body.clientWidth ==> BODY对象宽度

document.body.clientHeight ==> BODY对象高度

document.documentElement.clientWidth ==> 可见区域宽度

document.documentElement.clientHeight ==> 可见区域高度?

在Opera中: document.body.clientWidth ==> 可见区域宽度

document.body.clientHeight ==> 可见区域高度

document.documentElement.clientWidth ==> 页面对象宽度(即BODY对象宽度加上Margin宽)document.documentElement.clientHeight ==> 页面对象高度(即BODY对象高度加上Margin高)

而如果没有定义W3C的标准,

则IE为:document.documentElement.clientWidth ==> 0

document.documentElement.clientHeight ==> 0

FireFox为:document.documentElement.clientWidth ==> 页面对象宽度(即BODY对象宽度加上Margin宽)

document.documentElement.clientHeight ==> 页面对象高度(即BODY对象高度加上Margin高)

Opera为:document.documentElement.clientWidth ==> 页面对象宽度(即BODY对象宽度加上Margin宽)

document.documentElement.clientHeight ==> 页面对象高度(即BODY对象高度加上Margin高)

真是一件麻烦事情,其实就前端设计开发来看,宁可少一些对象和方法,不使用最新的标准要方便许多啊。但是跟不上潮流就永远做不了一个高级设计师,所以这些知识我们还是必须要理解和熟练掌握的。

Javascript 相关文章推荐
如何实现浏览器上的右键菜单
Jul 10 Javascript
jQuery总体架构的理解分析
Mar 07 Javascript
jquery复选框全选/取消示例
Dec 30 Javascript
DOM 事件流详解
Jan 20 Javascript
使用AngularJS实现可伸缩的页面切换的方法
Jun 19 Javascript
jQuery实现商品活动倒计时
Oct 16 Javascript
使用three.js 画渐变的直线
Jun 05 Javascript
jQuery验证表单格式的使用方法
Jan 10 Javascript
详解vue项目中如何引入全局sass/less变量、function、mixin
Jun 02 Javascript
Vue.js项目实战之多语种网站的功能实现(租车)
Aug 07 Javascript
nuxt+axios实现打包后动态修改请求地址的方法
Apr 22 Javascript
在vue中使用Base64转码的案例
Aug 07 Javascript
jQuery实现多按钮单击变色
Nov 27 #Javascript
jQuery的ready方法详解
Nov 27 #Javascript
javascript 面向对象封装与继承
Nov 27 #Javascript
javascript制作坦克大战全纪录(2)
Nov 27 #Javascript
javascript制作坦克大战全纪录(1)
Nov 27 #Javascript
使用jsonp完美解决跨域问题
Nov 27 #Javascript
JavaScript变量声明详解
Nov 27 #Javascript
You might like
帖几个PHP的无限分类实现想法~
2007/01/02 PHP
PHP $_SERVER详解
2009/01/16 PHP
PHP中Date()时间日期函数的使用方法小结
2011/04/20 PHP
php使用base64加密解密图片示例分享
2014/01/20 PHP
Yii中CGridView关联表搜索排序方法实例详解
2014/12/03 PHP
PHP实现的自定义图像居中裁剪函数示例【测试可用】
2017/08/11 PHP
PHP获取MySQL执行sql语句的查询时间方法
2018/08/21 PHP
JavaScript方法和技巧大全
2006/12/27 Javascript
event对象的方法 兼容多浏览器
2009/06/27 Javascript
客户端限制只能上传jpg格式图片的js代码
2010/12/09 Javascript
javascript提取URL的搜索字符串中的参数(自定义函数实现)
2013/01/22 Javascript
Js注册协议倒计时的小例子
2013/06/24 Javascript
面向切面编程(AOP)的理解
2015/05/01 Javascript
jQuery实现鼠标点击弹出渐变层的方法
2015/07/09 Javascript
理解JS绑定事件
2016/01/19 Javascript
AngularJS入门教程中SQL实例详解
2016/07/27 Javascript
JS中append字符串包含onclick无效传递参数失败的解决方案
2016/12/26 Javascript
jqueryUI tab标签页代码分享
2017/10/09 jQuery
javascript基于定时器实现进度条功能实例
2017/10/13 Javascript
在Vue项目中使用d3.js的实例代码
2018/05/01 Javascript
js中Array对象的常用遍历方法详解
2019/01/17 Javascript
微信小程序云开发 搭建一个管理小程序
2019/05/17 Javascript
JS实现多选框的操作
2020/06/24 Javascript
微信小程序地图实现展示线路
2020/07/29 Javascript
Python导入txt数据到mysql的方法
2015/04/08 Python
Python中类型关系和继承关系实例详解
2015/05/25 Python
python实现多人聊天室
2020/03/31 Python
python3正则模块re的使用方法详解
2020/02/11 Python
使用Python三角函数公式计算三角形的夹角案例
2020/04/15 Python
python定义类的简单用法
2020/07/24 Python
什么是WEB控件?使用WEB控件有哪些优势?
2012/01/21 面试题
如何写好升职自荐信
2014/01/06 职场文书
学习委员自我鉴定
2014/01/13 职场文书
党员2014两会学习心得体会
2014/03/17 职场文书
党的群众路线教育实践活动领导班子整改措施
2014/09/30 职场文书
合作与交流自我评价
2015/03/09 职场文书