JS下各种宽高
Window和Document:
JS下宽高分为挂载在Window对象和Document对象下的宽高属性,先说下Window和Document的区别:
Window对象表示浏览器中打开的窗口,window对象可以省略,比如window.alert()可以简写为alert()Document对象是Window对象的一部分,那么window.document.body我们可以写成document.body,浏览器的HTML文档成为Document对象
Window下的宽高属性:
注:innerWidth、innerHeight和outerWidth、outerHeight是不支持IE9以下版本的,而screen系列宽高则不存在兼容问题
参考图如下:
Document下的宽高属性:Docment下有三类属性:
- 与
client相关的宽高 - 与
offset相关的宽高 - 与
scroll相关的宽高
与client相关的宽高:
clientWidth和clientHeight该属性指的是元素的可视部分宽度和高度,即padding+content
- 如果没有滚动条,即为元素设定的高度和宽度
- 如果出现滚动条,滚动条会遮盖元素的宽高,那么该属性就是其本来宽高减去滚动条的宽高
clientLeft和clientTop这两个返回的是元素周围边框的厚度,如果不指定一个边框或者不定位该元素,它的值就是0
获取浏览器窗口可视区域大小在不同浏览器都实用的JS方案:
与offset相关宽高介绍:
offsetWidth与offsetHeight这一对属性指的是元素的border+padding+content的宽度和高度
该属性和其内部的内容是否超出元素大小无关,只和本来设定的border以及padding和content有关offsetLeft和offsetTop这两个属性是基于offsetParent的,了解这两个属性我们必须先了解什么是offsetParent
如果当前元素的父级元素没有进行CSS定位(position为absolute或relative),offsetParent为border.
假如当前元素的父级元素中有CSS定位,offsetParent取最近的那个父级元素。
- 在
IE6/7中:offsetLeft=(offsetParent的padding-left)+(当前元素的margin-left) - 在
IE8/9/10及Chrome中:offsetLeft=(offsetParent的margin-left)+(offsetParent的border宽度)+(offsetParent的padding-left)+(当前元素的margin-left) - 在
FireFox中:offsetLeft=(offsetParent的margin-left)+(offsetParent的padding-left)+(当前元素的margin-left)
与scroll相关宽高介绍:
scrollWidth和scrollHeight:
- 给定宽高小于浏览器窗口:
scrollWidth:浏览器窗口的宽度scrollHeight:浏览器窗口的高度 - 给定宽高大于浏览器窗口,且内容小于给定宽高:
scrollWidth:给定的宽度+其所有padding、margin、borderscrollHeight:给定的高度+其所有的padding、margin、border - 给定宽高大于浏览器窗口,且内容大于给定宽高:
scrollWidth:内容宽度+其所有的padding、margin、borderscrollHeight:内容高度+其所有的padding、margin、border
scrollLeft和scrollTop这对属性是可读写的,指的是当元素其中的内容超出其宽高的时候,元素被卷起来的宽度和高度
Event对象的5种坐标
|
|
JQuery下各种宽高
|
|
本文整理自慕课网课程《JS/jQuery宽高的理解和应用》