zoukankan      html  css  js  c++  java
  • CSSOM视图模型中几个常用的位置、尺寸相关属性的详解

    什么是CSSOM视图模型,这里就不解释了,有兴趣的童鞋可以到官网去看下。这里只说说几个很有用却容易混淆的属性,这几个属性兼容性都蛮不错的,基本不用太关注浏览器环境。

    clientLeft 与 clientTop

    返回元素内容区域左上边界(包含padding,并且是可见区域)相对于元素整个区域左上边界(包含边框,但不包含margin)的偏移距离,兼容常见浏览器(指ie6+,firefox 3.0+,chrome 4+,opera 10.10+,safari 4.0+等浏览器,后文相同)

    ps:可见区域是指我们能看到的部分,即不包括超出隐藏部分或是有滚动条时被隐藏的那部分。

    再ps:后文中如再提到元素的内容区域,则指的是包含padding后的区域,元素的整个区域指的是包含padding和border,但不包含margin的区域.

    offsetLeft 与 offsetTop

    返回元素的整个区域的左上边界相对于最近的有动态定位(也就是除static以外的定位)的祖先元素(也称为offsetParent)的内容区域左上边界的偏移距离.

    注:在ie6中,当offsetParent元素的position属性为relative时,则offsetLeft和offsetTop的计算点会变为文档的左上角,ie7+待测

    另:书上以及很多地方都说,offsetParent的最顶级元素(即页面中不存在有动态定位的祖先元素时,会取这个最顶级元素作为offsetParent)为body,但实际中,offsetParent的最顶级元素应为html,在绝对定位中,最高参照物也是html,而不是body

    ps: 在IE和Opera浏览器下,position属性为fixed的元素是没有offsetParent的。

    总结:clientLeft 与 clientTop的计算只涉及到一个元素,也就是自身,而offsetLeft 与 offsetTop则需要它父元素中的一个来参与计算,因此涉及到了两个元素。


    clientWidth 与 clientHeight

     返回元素内容区域(包含padding,但不包含边框和滚动条,并且是可见区域)的尺寸大小,兼容常见浏览器

    ps:有滚动条产生时,元素尺寸不会额外增大,而是从自身的空间里扣除

    offsetWidth 与 offsetHeight

    返回整个元素(包含padding和border)的大小,兼容常见浏览器

    总结:由以上几个属性可看出,带client的都是和元素内容区域相关,带offset的都是和元素的整个区域的相关的。

    scrollLeft 与 scrollTop

    返回元素已滚动部分的距离,兼容常见浏览器

    scrollWidth 与 scrollHeight

    返回元素的的clientWidth或clientHeight(包括超出隐藏的或滚动的部分),兼容常见浏览器

    注意:clientWidth或clientHeight是不包括超出隐藏或滚动部分的

    clientX 与 clientY

    返回鼠标事件时鼠标相对于浏览器窗口左上角的位置,与html或body的边框、内外边距等无关,兼容常见浏览器



  • 相关阅读:
    BestCoder Round #86 1001
    Codeforces Round #365 (Div. 2) B
    Codeforces Round #365 (Div. 2) A
    Codeforces Round #129 (Div. 2) C
    Codeforces Round #129 (Div. 2) B
    Android.mk 文件语法详解
    RDS和ROS使用小结
    电力企业计量生产需求系统解决方案
    android 修改framework下资源文件后如何编译
    USB port 如何识别不同的Charger类型
  • 原文地址:https://www.cnblogs.com/2050/p/2334046.html
Copyright © 2011-2022 走看看