clientWidth、offsetWidth、scrollWidth……

1、元素视图属性

clientWidth:元素内容可视区宽度(水平方向 width + 左右 padding)。

clientHeight:元素内容可视高度(垂直方向 height + 上下padding)。

offsetWidth:元素实际宽度(水平方向 width + 左右 padding + 左右 border-width)。

offsetHeight:元素实际高度(垂直方向 height + 上下 padding + 上下 border-width)。

scrollWidth:元素内容实际宽度,内容不超过盒子宽度时为盒子的 clientWidth(图1 A、B、C)。

scrollHeight:元素内容真实高度,内容不超过盒子高度为盒子的 clientHeight。

scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距离。
scrollTop:设置或获取位于对象最顶端和窗口中可见内容的最顶端之间的距离,或当元素内容高度超过元素本身高度时,scrollTop 指的是元素内容超出元素上边界的那部分高度。

clientLeft:元素 border-left 的 width,也可以视为 ( offsetWidth  - clientWidth ) / 2。

clientTop:元素 border-top 的width ,也可视为(offsetHeight - clientHeight)/ 2。

offsetLeft:元素到 offsetParent 左侧距离(不包括父元素的 border 值,如图三)。

offsetTop:元素到 offsetParent 顶部距离。

offsetParent:距离元素最近的一个具有定位的父级元素(relative,absolute,fixed),如果父级元素都不是定位元素,offsetParent 为浏览器窗口最边边(大部分资料说 body,但如图测试 offsetLeft 却包含 html 的 border-left 宽)。

如图二,火狐浏览器的 offsetLeft 不包含 body 的 border-left 值,其余部分浏览器包含。

 

2、window 视图属性,(于分辨率1920 * 1080下F11全屏放大屏幕所测,包含滚动条)

innerWidth:浏览器窗口可视区宽度(不包括浏览器控制台、菜单栏、工具类)【1920px】

innerHeight:浏览器窗口可视区高度(不包括浏览器控制台、菜单栏、工具类)【1080px】

 

3、document 文档视图

document.documentElement.clientWidth:浏览器窗口可视区宽度(不包含浏览器控制台、菜单栏、工具栏、滚动条)。

document.documentElement.clientHeight:浏览器窗口可视区高度(不包含浏览器控制台、菜单栏、工具栏、滚动条)。

document.documentElement.offsetWidth:获取DOM文档根节点 html 元素对象的宽度,即offsetWidth  = width + padding +border,不包括margin。

document.documentElement.offsetHeight:获取DOM文档根节点 html 元素对象的高度,即offsetHeight = height + padding + border,不包括margin(包括 body 的 margin)。

document.documentElement.scrollWidth:获取 html 元素对象内容的实际宽度,即 html 元素对象的滚动宽度。

document.documentElement.scrollHeight:获取 html 元素对象内容的实际高度,即 html 元素对象的滚动高度。

document.documentElement.clientLeft:获取 html 元素对象左边框宽度。

document.documentElement.clientTop:获取 html 元素对象上边框宽度。

document.documentElement.scrollLeft:返回文档滚动 left 方向距离(当窗口发生滚动时值改变)。

document.documentElement.scrollTop:返回文档滚动 top 方向距离(当窗口发生滚动时值改变)。

document.documentElement.offsetLeft:设置或获取页面文档向右滚动或的像素数。

document.documentElement.offsetTop:设置或获取页面文档向下滚动过的像素数。

document.body.offsetHeight:获取整个文档高度(不包含 body 的 margin )。

 

 

 

 

 

scrollHeight:元素内容的高度

  对于 #parent 元素来说,其元素内容就是#child元素的高度,因为#child设置overflow:hidden,所以,#paren 的 scrolllHeight 为300;
  对于 #child 元素来说,其元素内容就是 01<br/> ~ 20<br/>,其中一行高度是21,故 #child 的 scrollHeight为 420


scrollTop:当元素内容高度超过元素本身高度时,scrollTop 指的是元素内容超出元素上边界的那部分高度。
  设 parent.scrollTop = 21时,相当于 #child 往下滚动,顶部内容距离 #parent 21数值,此时 #child的内容从02显示。
  设 child.scrollTop = 42时, 相当于 #child 的内容往下滚动显示,部分内容距离 #child顶部 42数值,02、03往上移,故04开始显示。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        #parent {
            position: relative;
            overflow: auto;
            width: 100px;
            height: 100px;
            background: #f1a899;
        }

        #child {
            position: relative;
            overflow: hidden;
            width: 50px;
            height: 300px;
            background: #84b3fd;
        }
    </style>
</head>
<body>
<div id="parent">
    <div id="child">
        01<br/>
        02<br/>
        03<br/>
        04<br/>
        05<br/>
        06<br/>
        07<br/>
        08<br/>
        09<br/>
        10<br/>
        11<br/>
        12<br/>
        13<br/>
        14<br/>
        15<br/>
        16<br/>
        17<br/>
        18<br/>
        19<br/>
        20<br/>
    </div>
</div>
<script>
    var parent = document.getElementById("parent");
    parent.scrollTop = 21;
    console.log("parent.scrollHeight: " + parent.scrollHeight); // 300
    console.log("parent.scrollTop: " + parent.scrollTop); // 21  设置 parent.scrollTop = 21,此时 #迟不设置则为 0
    console.log("parent.offsetHeight: " + parent.offsetHeight); // 100

    console.log("---------------------------");

    var child = document.getElementById("child");
    child.scrollTop = 42;
    console.log("child.scrollHeight: " + child.scrollHeight); // 420
    console.log("child.scrollTop: " + child.scrollTop); // 42 设置 child.scrollTop = 42,不设则为 0
    console.log("child.offsetTop: " + child.offsetTop); // 0
</script>
</body>
</html>

 

posted @ 2021-07-26 18:01  し7709  阅读(381)  评论(0编辑  收藏  举报