用js小类库获取浏览器的高度和宽度信息

标签: js 类库 浏览器 | 发表时间:2012-01-15 01:43 | 作者:执手泪眼
出处:http://www.cnblogs.com/

在做项目时碰到了要在页面上显示一个浮动DIV层的效果。本来做的是在页面居中时显示的,但后来经过自己的测试发现,当网页中出现了滚动条之后,那个浮动的DIV却还是在页面的顶部显示的。因此当用户在一个较长内容的网页中点击某一个按钮显示DIV层会发现没有任何效果(其实已经在页面的顶部显示了),因此,我们需要准备的知道用户当前的浏览的位置的信息。在实现这个要求之前,先来看看在js中有哪些工具可以让我们使用:

网页可见区域宽: document.body.clientWidth;
网页可见区域高: document.body.clientHeight;
网页可见区域宽: document.body.offsetWidth + " (包括边线和滚动条的宽)";
网页可见区域高:document.body.offsetHeight + " (包括边线的宽)";
网页正文全文宽:document.body.scrollWidth;
网页正文全文高:document.body.scrollHeight;
网页被卷去的高(ff): document.body.scrollTop;
网页被卷去的高(ie):document.documentElement.scrollTop;
网页被卷去的左:document.body.scrollLeft;
网页正文部分上: window.screenTop;
网页正文部分左: window.screenLeft;
屏幕分辨率的高: window.screen.height;
屏幕分辨率的宽: window.screen.width;
屏幕可用工作区高度: window.screen.availHeight;
屏幕可用工作区宽度: window.screen.availWidth;
你的屏幕设置是  window.screen.colorDepth +" 位彩色";
你的屏幕设置  window.screen.deviceXDPI +" 像素/英寸";

 

这段资料来源于网络,看到这么多的相似的概念时我已经疯掉了,但处于技术人的执着,我还是顽强的看完了并做了一些理解。经过自己的理解和吸收之后,我觉得如果我每次想获取一个高度或者宽度信息时我会抓狂的,因此,我对浏览器的这些属性做了一些整理和抽象,按照这样的三个对象来剥离这么多的相似的属性,第一个是页面,第二是窗口,第三个是视口。来看图片理解我的这三个对象的含义吧:

浏览器三层

对这三个概念做一个解释:

页面:就是我们制作出来的网页的页面的一个抽象,他的高度通常比我们的浏览器的高度要高,宽度通常是小于等于我们的浏览器宽度

浏览器窗口:就是我们使用的浏览器的一个抽象,他包含了菜单栏、工具栏、书签栏、状态栏、页面显示区等。因此他的高度绝对大于等于视口的高度,宽度绝对大于等于视口的宽度

视口:就是浏览器中显示页面的区域

有了这三个概念铺底,我们来写个小类库,获取这个“对象”的高度和宽度等信息吧:

 

var Browser = {

};

//页面
Browser.Page = (function () {

    return {
        scrollTop: function () {
            return Math.max(document.body.scrollTop, document.documentElement.scrollTop);
        },
        scrollLeft: function () {
            return Math.max(document.body.scrollLeft, document.documentElement.scrollLeft);
        },
        height: function () {
            var _height;
            if (document.compatMode == "CSS1Compat") {
                _height = document.documentElement.scrollHeight;
            } else {
                _height = document.body.scrollHeight;
            }
            return _height;
        },
        width: function () {
            var _width;
            if (document.compatMode == "CSS1Compat") {
                _width = document.documentElement.scrollWidth;
            } else {
                _width = document.body.scrollWidth;
            }
            return _width;
        }

    };

})();


//窗口:
Browser.Window = (function () {

    return {
        outerHeight: function () {
            var _hei = window.outerHeight;
            if (typeof _hei != "number") {
                _hei = Browser.ViewPort.outerHeight();
            }
            return _hei;
        },
        outerWidth: function () {
            var _wid = window.outerWidth;
            if (typeof _wid != "number") {
                _wid = Browser.ViewPort.outerWidth();
            }
            return _wid;
        },
        innerHeight: function () {
            var _hei = window.innerHeight;
            if (typeof _hel != "number") {
                _hei = Browser.ViewPort.innerHeight();
            }
            return _hei;
        },
        innerWidth: function () {
            var _wid = window.innerWidth;
            if (typeof _wid != "number") {
                _wid = Browser.ViewPort.innerWidth();
            }
            return _wid;
        },
        height: function () {
            return Browser.Window.innerHeight();
        },
        width: function () {
            return Browser.Window.innerWidth();
        }
    }

})();


//视口:
Browser.ViewPort = (function () {

    return {
        innerHeight: function () {
            var _height;
            if (document.compatMode == "CSS1Compat") {
                _height = document.documentElement.clientHeight;
            } else {
                _height = document.body.clientHeight;
            }
            return _height;
        },
        innerWidth: function () {
            var _width;
            if (document.compatMode == "CSS1Compat") {
                _width = document.documentElement.clientWidth;
            } else {
                _width = document.body.clientWidth;
            }
            return _width;
        },
        outerHeight: function () {
            var _height;
            if (document.compatMode == "CSS1Compat") {
                _height = document.documentElement.offsetHeight;
            } else {
                _height = document.body.offsetHeight;
            }
            return _height;
        },
        outerWidth: function () {
            var _width;
            if (document.compatMode == "CSS1Compat") {
                _width = document.documentElement.offsetWidth;
            } else {
                _width = document.body.offsetWidth;
            }
            return _width;
        },
        width: function () {
            return Browser.ViewPort.innerWidth();
        },
        height: function () {
            return Browser.ViewPort.innerHeight();
        }
    }

})();

 

做几点说明:

1、已经能支持获取多浏览器的内部的视口的宽度和高度信息

2、在IE 9中已经和其他的浏览器(Opera、Chrome、FirFox、Safari)一样,已经能支持用window.innerHeight、window.innerWidth、window.outerHeight、window.outerWidth这四个属性获取浏览器的窗口、视口的宽度高度信息,但是IE9以前的IE版本是没有这些属性的,因此在这样的情况下,我将视口和窗口的概念等同起来了。

2、虽然window有宽度和高度信息,但是不一定是真正浏览器窗口的真正的宽度和高度信息。因为有些浏览器返回的结果中就不含菜单栏、工具栏等的高度信息。

 

实例演示:

在一个垂直内容过多的页面中,使一个DIV总能保持在视口的中心位置(非精确中心位置):

代码:

window.onload = window.onresize = function () {

            var top = Math.round(Browser.Page.scrollTop() + (Browser.ViewPort.height() / 2) - (parseInt(document.getElementById("divCenter").style.height) / 2));
            var left = Math.round(Browser.Page.scrollLeft() + (Browser.ViewPort.width() / 2) - (parseInt(document.getElementById("divCenter").style.width) / 2));

           
            document.getElementById("divCenter").style.top = top + "px";
            document.getElementById("divCenter").style.left = left + "px";

        }

 

大家测试时可以采用改变窗口大小的方式来查看。

 

时间不早了,晚安!

 

源代码下载查看

本文链接

相关 [js 类库 浏览器] 推荐:

用js小类库获取浏览器的高度和宽度信息

- - 博客园_首页
在做项目时碰到了要在页面上显示一个浮动DIV层的效果. 本来做的是在页面居中时显示的,但后来经过自己的测试发现,当网页中出现了滚动条之后,那个浮动的DIV却还是在页面的顶部显示的. 因此当用户在一个较长内容的网页中点击某一个按钮显示DIV层会发现没有任何效果(其实已经在页面的顶部显示了),因此,我们需要准备的知道用户当前的浏览的位置的信息.

JS跨浏览器解析XML应用

- - ITeye博客
对于XML,我们可以理解它是一种树结构,它包含根,元素,属性,文本等内容. 不同浏览器都有自己的解析器,把XML读入内存,并把它转换为可被 JavaScript 访问的 XML DOM 对象. 微软的 XML 解析器与其他浏览器中的解析器是有差异的. 微软的解析器支持对 XML 文件和 XML 字符串(文本)的加载,而其他浏览器使用单独的解析器.

js实现浏览器全屏

- - Web前端 - ITeye博客
  HTML 5中的full screen,目前可以在除IE和opera外的浏览器中使用 ,有的时候用来做 . 全屏API,游戏呀,等都很有用.     作用:请求某个元素element全屏 .   这里是将其中的元素ID去请求fullscreen .   如果用户在全屏模式下,则返回true .   返回当前处于全屏模式下的元素 .

用html5 js实现浏览器全屏 - 天魂地煞

- - 博客园_首页
项目中需要将后台浏览器的窗口全屏,也就是我们点击一个按钮要实现按F11全屏的效果. 在HTML5中,W3C制定了关于全屏的API,就可以实现全屏幕的效果,也可以让页面中的图片,视频等全屏目前只有google chrome 15 +, safri5.1+,firfox10+,IE11支持. "" : "not ";}, false); 全屏样式设置.

【Web 开发必备】 史上最全的浏览器 CSS & JS Hack 手册

- - 博客园_首页
  浏览器渲染页面的方式各不相同,甚至同一浏览器的不同版本(“杰出代表”是 IE)也有差异. 因此,浏览器兼容成为前端开发人员的必备技能. 如果有一份浏览器 Hack 手册,那查询起来就方便多了. 这篇文章就向大家分享 Browserhacks 帮我们从网络上收集的各个浏览器特定的 CSS & JavaScript Hack,记得推荐和分享啊.

纯js实现浏览器图片选择预览、旋转、批量上传

- - ITeye博客
工作中遇到的业务场景,和同事一起研究了下,主要是为了兼容IE版本. 其实就是一些琐碎的知识点在网上搜集下解决方式,然后集成了下,主要有以下点:. IE input type=file的图片预览要用IE的filter css.    chrome/firefox则用File api的file reader.

一句话解决JS获得图片尺寸问题,兼容各个浏览器

- - CSDN博客推荐文章
之前用到图片等比缩小或者懒加载或者预加载之类的都要首先获得图片的高度和宽度,到网上看别人 用 Image 对象 使用 image.width,image.height 或者使用一个div包裹图片,不设置图片的高和宽,然后获得div的宽和高就是图片的高和宽,但是经过本人实验 首先使用image对象的方法获得尺寸,很不靠谱,特在IE7上面 ,很坑爹,存在很多兼容性问题.

JS获取Ip和浏览器信息,用户逗留时间写进数据库

- - ITeye博客
data: "{IP:'" + IP + "',city:'" + city + "',fromURL:'" + fromURL + "',Browse:'" + Browse + "',time:'" + time + "'}",. 已有 0 人发表留言,猛击->> 这里<<-参与讨论. —软件人才免语言低担保 赴美带薪读研.

超棒的30款JS类库和工具

- - 互联网分析
当设计人员和开发人员真正快速便捷的使用JavaScript类库和工具的同时,他们的生活也就变得更轻松、简单. 你付出的越多,它回报你的也就越多,这正是JS类库和工具需求量很大的原因. 对于Web设计人员和开发人员来说,手里有一套便利的、最新的工具可供使用是极其重要的. Web设计和开发的趋势变化极快,所以拥有最新的工具是必不可少的.

现代浏览器的web音频javascript类库 - Howler.js

- - CSDN博客Web前端推荐文章
日期:2013-2-6  来源: GBin1.com. 浏览器这个玩意儿并不是个新鲜事,但是随着HTML5的发展激起了浏览器技术的巨大发展. 但是浏览器上对于音频控制技术来说仍旧非常的落伍. 庆幸的是 Google积极的开发和创建了web audio API,这使得基于浏览器的音频控制更加的简单并且直观.