client、offset、scroll
1. client 客户区大小
1.1. clientHeight和clientWidth
element.clientHeight表示元素可视区域的高度,包括可视区域中元素的
CSS height+padding , 不包括边框、滚动条、不可见部分、margin。
1.2. clientLeft和clientTop
1.3. 获取浏览器可视区大小(兼容处理)
2. offset偏移量
2.1. offsetParent
是一个只读属性,获取的最近的定位的父元素。
1)如果child有定位的父元素,offsetParent就是定位的父元素;
2)如果没有定位的父元素,offsetParent就是body
2.2. offsetLeft和offsetTop
相对于定位的父级offsetParent内边距的距离,如果没有定位父元素,则以body为准。(即child的border边界距离offsetParent padding边界的距离,不包括child的margin部分)
2.2.1. 与style.left的区别:
1)、style.left只能获取行内样式
2)、offsetLeft只读,style.left可读可写
3)、offsetLeft是数值,style.left是字符串并且有单位px
4)、如果没有加定位,style.left获取的数值可能是无效的
5)、最大区别在于offsetLeft以border左上角为基准,style.left以margin左上角为基准
2.3. offsetWidth 和 offsetHeight
用来得到对象的大小,可以获得元素在内嵌样式里的宽度和高度
offsetWidth的组成: width+padding+border
2.3.1. 与style.width的区别
1)demo.style.witdh只能获取到行内样式,如果样式写到了其他地方,甚至根本就没写,便无法获取
2)style.width是字符串(而且带单位),offsetWidth是数字
3)demo.style.width可以设置行内样式,offsetWidth是只读属性
3. scroll 滚动大小
3.1. scrollHeight 和 scrollWidth 滚动内容的大小
element.scrollHeight属性是只读的,它包括:
滚动内容的高度(撑开之后内容的大小) height + padding 不包括边框
<style>
2 * {
3 margin: 0;
4 padding: 0;
5 }
6 #box {
7 width: 100px;
8 height: 100px;
9
10 border: 5px solid red;
11 padding: 20px;
12 }
13 </style>
14
15
16
17 //height + padding 获取撑开之后内容的大小
18 console.log(box.scrollHeight);
19
20 //border + width + padding 盒子的大小
21 console.log(box.offsetHeight);
3.2. scrollTop 和scrollLeft
scrollTop 获取滚动出去的距离
onscroll 滚动事件
3.2.1. 获取页面滚动出去的距离以及兼容处理
scrollTop、scrollLeft在获取页面滚动时有兼容问题
标准浏览器下: document.body.scrollTop
Ie8下: document.documentElement.scrollTop
window.pageYOffset:是DOM中标准的属性,但是IE的老版本不支持
3.2.2. 封装兼容浏览器函数function scroll()
client、offset、scroll的更多相关文章
- 前端 ---client、offset、scroll系列
client.offset.scroll系列 1.client系列 代码如下: <!DOCTYPE html> <html> <head> <meta c ...
- python 全栈开发,Day52(关于DOM操作的相关案例,JS中的面向对象,定时器,BOM,client、offset、scroll系列)
昨日作业讲解: 京东购物车 京东购物车效果: 实现原理: 用2个盒子,就可以完整效果. 先让上面的小盒子向下移动1px,此时就出现了压盖效果.小盒子设置z-index压盖大盒子,将小盒子的下边框去掉, ...
- 4.client、offset、scroll系列
client.offset.scroll系列 他们的作用主要与计算盒模型.盒子的偏移量和滚动有关 clientTop 内容区域到边框顶部的距离 ,说白了,就是边框的高度 clientLeft 内容区域 ...
- JavaScript-client、offset、scroll、定时器
client offset scroll client.offset.scroll系列 他们的作用主要与计算盒模型,盒子的偏移量和滚动有关 clientTop 内容区域到边框顶部的距离, 说白了, 就 ...
- JavaScript学习笔记5 之 计时器 & scroll、offset、client系列属性 & 图片无缝滚动
一.计时器 setInterval ( 函数/名称 , 毫秒数 )表示每经过一定的毫秒后,执行一次相应的函数(重复) setTimeout ( 函数/名称 , 毫秒数 ) 表示经过一定的毫秒后,只执行 ...
- 区别client、offset、scroll系列以及event的几个距离属性
element元素结点属性 一. offset系列 1.offsetWidth 和offsetHeight element.offsetWidth是一个只读属性,它包括了: css width + p ...
- python 全栈开发,Day54(关于DOM操作的相关案例,JS中的面向对象,定时器,BOM,client、offset、scroll系列)
04-jQuery的属性操作 jquery的属性操作模块分为四个部分:html属性操作,dom属性操作,类样式操作和值操作 html属性操作:是对html文档中的属性进行读取,设置和移除操作.比如at ...
- 各种位置和高度计算:.position()、.offset()、.outerHeight()、.scrollTop、.scrollHeight、.clientHeight
1..position()和.offset() jquery的.position()获取相对于最近的position为relative或absolute的父元素的偏移,返回.position().le ...
- 差别client、offset、scroll系列以及event的几个距离属性
element元素结点属性 一. offset系列 1.offsetWidth 和offsetHeight element.offsetWidth是一个仅仅读属性,它包含了: css width + ...
随机推荐
- 2013.10.26工作Fighting(1)
1.今天虽然花费了六个小时来解决一个功能,最后用一行代码来搞定了. ----遇到问题,解决的办法总是比问题多. 2.给你分配有难度的任务,应该是激动.这样才能挑战自我,学得到很多兴奋的新东西. --- ...
- C#的接口基础教程之二 定义接口
定义接口 从技术上讲,接口是一组包含了函数型方法的数据结构.通过这组数据结构,客户代码可以调用组件对象的功能. 定义接口的一般形式为: [attributes] [modifiers] interfa ...
- 移动端调试利器-vConsole
现在移动端开发越来越火,随之而来的问题也越来越多,今天给大家介绍一款移动端调试神器,vconsole. 一.先引用文件,可以从https://www.bootcdn.cn/vConsole/下载,也可 ...
- C++ ADL
即在一个名称作为调用运算符的左操作数时,并且这个名字是一个无限定名称时,在无限定查找到的名字集合中额外增加的一个规则使集合范围扩大(从而可以定位到其他一些限定名称),通常是用来保证定义在不同命名空间的 ...
- SummerVocation_Learning--java的自动打包与解包
Auto Boxing: 自动将基础类型转换成对象(JDK1.5之后支持) Auto UnBoxing:自动将对象转换成基础类型 如 Map中的put方法,如果要传入键值对<a,1>,&l ...
- 2018.10.30 NOIp模拟赛T2 数字对
[题目描述] 小 H 是个善于思考的学生,现在她又在思考一个有关序列的问题. 她的面前浮现出一个长度为 n 的序列{ai},她想找出一段区间[L, R](1 <= L <= ...
- 【前端_js】js中数字字符串之间的比较
js中字符串间的比较是按照位次优先,比较各字符的ASCII大小,包括数字字符串之间的比较. 1.console.log("1"<"3");//true 2 ...
- 二 python并发编程之多进程-理论
一 什么是进程 进程:正在进行的一个过程或者说一个任务.而负责执行任务则是cpu. 举例(单核+多道,实现多个进程的并发执行): egon在一个时间段内有很多任务要做:python备课的任务,写书的任 ...
- Yii 2.x html 代码压缩
<?php namespace Pangu\web; use yii\base\Component; /** * html格式响应内容格式化 * @author zhouzhian * */ c ...
- Gender Equality in the Workplace【职场上的性别平等】
Gender Equality in the Workplace A new batch of young women - members of the so-called Millennial ge ...