JS获取屏幕分辨率 及 窗口尺寸

时间:2025-01-21 14:37:40

网页可见区域宽:
网页可见区域高:
网页可见区域宽: (包括边线的宽)
网页可见区域高: (包括边线的宽)
网页正文全文宽:
网页正文全文高:
网页被卷去的高:
网页被卷去的左:
网页正文部分上:
网页正文部分左:
屏幕分辨率的高:
屏幕分辨率的宽:
屏幕可用工作区高度:
屏幕可用工作区宽度:

获取窗口宽度:
获取窗口高度:

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

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文档的根节点。
表示HTML文档所在窗口的当前高度。. clientWidth表示HTML文档所在窗口的当前宽度。

实现代码:

<!DOCTYPE html
    PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http:///TR/xhtml1/DTD/">
<html xmlns="http:///1999/xhtml">

<head>
    <title>请调整浏览器窗口</title>
    <meta http-equiv="content-type" content="text/html; charset=gb2312">
</head>

<body>
    <h2 align="center">请调整浏览器窗口大小</h2>
    <hr>
    <form action="#" method="get" name="form1" id="form1">
        <!--显示浏览器窗口的实际尺寸-->
        浏览器窗口 的 实际高度: <input type="text" name="availHeight" size="4"><br>
        浏览器窗口 的 实际宽度: <input type="text" name="availWidth" size="4"><br>
    </form>
    <script type="text/javascript">
        var winWidth = 0;
        var winHeight = 0;
        function findDimensions() //函数:获取尺寸
        {
            //获取窗口宽度
            if (window.innerWidth)
                winWidth = window.innerWidth;
            else if ((document.body) && (document.body.clientWidth))
                winWidth = document.body.clientWidth;
            //获取窗口高度
            if (window.innerHeight)
                winHeight = window.innerHeight;
            else if ((document.body) && (document.body.clientHeight))
                winHeight = document.body.clientHeight;
            //通过深入Document内部对body进行检测,获取窗口大小
            if (document.documentElement && document.documentElement.clientHeight && document.documentElement.clientWidth) {
                winHeight = document.documentElement.clientHeight;
                winWidth = document.documentElement.clientWidth;
            }
            //结果输出至两个文本框
            document.form1.availHeight.value = winHeight;
            document.form1.availWidth.value = winWidth;
        }
        findDimensions();
        //调用函数,获取数值
        window.onresize = findDimensions;
    </script>
</body>

</html>