zoukankan      html  css  js  c++  java
  • scroll、offset和client的区别

    整体布局:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    <!DOCTYPE>
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>比较</title>
    <style type="text/css">
    *{
        padding: 0;
        margin: 0;
    }
    body{
        margin: 0;
        padding: 0;
         1500px;
        height:2000px;
        border: 1px solid;
    }
    div{
        border: 1px solid;
        left: 100px;
        position: relative;
        top: 100px;
         100px;
        height: 100px;
    }
    </style>
    </head>
    <body>
    <div id="div1"></div>
    </body>
    </html>

      

     

    1.clientX与clientY

    window.onload=function(){
     document.onclick=function(ev){
     var oEvent=ev||event;
     alert(oEvent.clientX+","+oEvent.clientY);
        }
    }

    oEvent.clientX是指鼠标到可视区左边框的距离。

    oEvent.clientY是指鼠标到可视区上边框的距离。

    2.offsetWidth、offsetHeight、offsetLeft和offsetTop

    window.onload=function(){
     var oDiv=document.getElementById("div1");
     alert(oDiv.offsetWidth);
     alert(oDiv.offsetHeight);
     alert(oDiv.offsetLeft);
     alert(oDiv.offsetTop);
    }

    offsetWidth是指div的宽度(包括div的边框)

    offsetHeight是指div的高度(包括div的边框)

    offsetLeft是指div到整个页面左边框的距离(不包括div的边框)

    offsetLeft
    该元素与距离最近的定位父元素间的距离,不能直接说是整个页面(这里因为元素只有一个div,所以是与html的距离)

    offsetTop是指div到整个页面上边框的距离(不包括div的边框)

    3.scrollTop、scrollLeft、scrollWidth和scrollHeight

    scrollTop是指可视区顶部边框与整个页面上部边框的看不到的区域。

    scrollLeft是指可视区左边边框与整个页面左边边框的看不到的区域。

    scrollWidth是指左边看不到的区域加可视区加右边看不到的区域即整个页面的宽度(包括边框)

    scrollHeight是指上边看不到的区域加可视区加右边看不到的区域即整个页面的高度(包括边框)

    4.clientWidth、clientHeight、clientLeft和clientTop

    clientWidth是指可视区的宽度。

    clientHeight是指可视区的高度。

    clientLeft获取左边框的宽度。

    clientTop获取上边框的宽度。

    5.如何兼容

    if(document.compatMode == "BackCompat") {//渲染方式
        wHeight = document.body.clientHeight;
    }else {//"CSS1compat"
        wHeight = document.documentElement.clientHeight;
    }

    offsetHeight: 元素高,height+border+padding
    offsetWidth: 元素宽,width+border+padding
    offsetTop: 上边距离带有定位的父盒子的距离(重要)
    offsetLeft: 左边距离带有定位的父盒子的距离(重要)
    offsetParent: 最近的带有定位的父盒子


    scrollHeight: 内容高,不含border
    scrollWidth: 内容宽,不含border
    scrollTop: document.documentELement.scrollTop || document.body.scrollTop; (重要)window.pageXOffset;
    浏览器页面被卷去的头部
    元素调用.必须具有滚动条的盒子调用。盒子本身遮挡住的子盒子内容。
    子盒子被遮挡住的头部
    scrollLeft: document.documentELement.scrollLeft: || document.body.scrollLeft: ; (重要)window.pageYOffset;
    浏览器页面被卷去的左侧
    元素调用.必须具有滚动条的盒子调用。盒子本身遮挡住的子盒子内容。
    子盒子被遮挡住的左侧


    clientHeight: 元素高,height+padding;
    window.innerHeight; document.body.clientHeight 可视区域的高
    clientWidth: 元素宽,width+padding;
    window.innerWidth; document.documentElementWidth; 可视区域的宽
    clientTop: 元素的上border宽
    clientLeft: 元素的左border宽
    clientY 调用者:event.clientY(event)(重要)
    作用:鼠标距离浏览器可视区域的距离,上
    clientX 调用者:event.clientX(event)(重要)
    作用:鼠标距离浏览器可视区域的距离,左

  • 相关阅读:
    Jquery清除style样式
    合并单元格式
    SQL根据下标,返回split分割后字符串
    js功能比较全面的yyyyMMdd格式的日期验证正则
    DataTable to Json
    List<T>下的Find,FindAll等条件过滤函数的使用方法
    获取iframe内部DOM对象
    PowerDesigner取消Name与Code同步
    再次回归
    最近遇到一个比较有意思的题目
  • 原文地址:https://www.cnblogs.com/powerplay/p/7690082.html
Copyright © 2011-2022 走看看