经常碰到offset、scroll、client这几个关键字,每次都要各种实验,这里总结一下。
两张图镇楼,随时翻阅
offset 指偏移,包括这个元素在文档中占用的所有显示宽度,包括滚动条、padding、border,不包括overflow隐藏的部分
offsetParent属性返回一个对象的引用,这个对象是距离调用offsetParent的父级元素中最近的(在包含层次中最靠近的),并且是已进行过CSS定位的容器元素。 如果这个容器元素未进行CSS定位, 则offsetParent属性的取值为根元素的引用。
position为absolute/relative),offsetParent为bodyposition为absolute/relative),offsetParent取父级中最近的元素overflow 而未显示的部分,也就是其实际占据的宽度,整型,单位:像素。
offsetWidth = border-width*2+padding-left+width+padding-right offsetHeight = border-width*2+padding-top+height+padding-bottom offsetParent 属性指定的父坐标的计算上侧位置,整型,单位:像素。
offsetTop= offsetParent的padding-top + 中间元素的offsetHeight + 当前元素的margin-topoffsetParent 属性指定的父坐标的计算左侧位置,整型,单位:像素。
offsetLeft= offsetParent的padding-left + 中间元素的offsetWidth + 当前元素的margin-leftscroll指滚动,包括这个元素没显示出来的实际宽度,包括padding,不包括滚动条、border
client指元素本身的可视内容,不包括overflow被折叠起来的部分,不包括滚动条、border,包括padding
网上的帖子大多深浅不一,甚至有些前后矛盾,在下的文章都是学习过程中的总结,如果发现错误,欢迎留言指出~
参考: