元素三大系列
这里讲的三大系列的属性返回的是数值,不带单位
元素偏移量 offset 系列
使用 offset 系列相关属性可以动态得到该元素的位置(偏移)、大小等。
作用:
- 获得元素距离定位父元素的位置(如果没有父元素或者父元素都没有定位,则是距离 body 的位置)
- 获得元素自身宽度高度
返回的是数值,不带单位
offset 系列常用属性:
offset 系列属性 | 作用 |
---|---|
element.offsetParent | 返回该元素带有定位的父级元素,都没有定位则返回 body |
element.offsetTop | 返回该元素相对于带有定位父元素上方的偏移 |
element.offsetLeft | 返回该元素相对于带有定位父元素左边框的偏移 |
element.offsetWidth | 返回该元素自身包括 padding、边框、内容区的宽度) |
element.offsetHeight | 返回该元素自身高度(同上) |
返回的是数值,不带单位
offset 和 style 的区别
offset | style |
---|---|
offset 可以得到所有样式表的样式值 | style 只能得到行内样式表中的样式值 |
offset 得到的是数值,没有单位 | style 得到的是带有单位的字符串 |
offsetWidth 包含 width+padding+border | style.width 只包含 width,不包含 padding 和 border |
offset 系列属性是只读属性,只能获取不能赋值 | style.width 等是可读写属性,可以获取也能赋值 |
获取元素大小位置,offset更合适,更改元素大小位置,style更合适
offset 各属性示意图:
例子:
案例
拖动的模态框
元素可视区 client 系列
使用 client 系列相关属性来获取元素可视区的相关信息。
作用:
- 动态得到该元素的边框大小
- 动态得到该元素的元素大小
返回的是数值,不带单位
client 系列属性 | 作用 |
---|---|
element.clientTop | 返回元素上边框大小 |
element.clientLeft | 返回元素左边框大小 |
element.clientWidth | 返回自身包括 padding、内容区的宽度,不含边框 |
elemeng.clientHeight | 返回自身高度(同上) |
返回的是数值,不带单位
示例:
立即执行函数
1 |
|
作用:创建一个独立的作用域,避免命名冲突的问题,因为里面的变量都是局部变量。
第一种形式比较好理解,首先需要定义函数,但是是立即执行函数,所以不需要函数名,不加函数名的话有可能是写错代码了,所以立即执行函数的语法就是用”()”包住立即执行函数,就可以区分出错误代码和立即执行函数。之后的”()”便是函数调用。
示例:
1 |
|
元素滚动 scroll 系列
使用 scroll 系列的相关属性可以动态的得到该元素的大小,滚动距离等。
返回的是数值,不带单位
scroll 系列属性 | 作用 |
---|---|
element.scrollTop | 返回被卷去的上侧距离 |
element.scrollLeft | 被卷去的左侧距离 |
element.scrollWidth | 返回自身实际宽度,不含边框 |
element.scrollHeight | 返回自身实际高度(同上) |
返回的是数值,不带单位
scrollWidth、scrollHeight:返回自身实际宽度、高度,即使内容区的内容不显示出来
示例:
案例:
仿淘宝固定侧边栏
知识点:
element.scrollTop 是返回元素被卷去的上侧距离,而 window.pageYOffset 是页面被卷去的距离
总结
返回的是数值,不带单位
三大系列大小对比 | 作用 |
---|---|
element.offsetWidth | 返回自身包括 padding、边框、内容区的宽度 |
element.clientWidth | 返回自身包括 padding、内容区的宽度,不含边框 |
element.scrollWidth | 返回自身实际的宽度,不含边框 |
用法:
- offset 系列经常用于获得元素位置(offsetTop、offsetLeft)
- client 系列经常用于获取元素大小(clientWidth、clientHeight)
- scroll 经常用于获取滚动距离(scrollTop、scrollLeft)
- 页面滚动距离不是通过 scrollTop、scrollLeft 获取,而是通过 window.pageXOffset、window.pageYOffset 获取
学习链接:
pink 老师前端入门