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的更多相关文章

  1. 前端 ---client、offset、scroll系列

    client.offset.scroll系列   1.client系列 代码如下: <!DOCTYPE html> <html> <head> <meta c ...

  2. python 全栈开发,Day52(关于DOM操作的相关案例,JS中的面向对象,定时器,BOM,client、offset、scroll系列)

    昨日作业讲解: 京东购物车 京东购物车效果: 实现原理: 用2个盒子,就可以完整效果. 先让上面的小盒子向下移动1px,此时就出现了压盖效果.小盒子设置z-index压盖大盒子,将小盒子的下边框去掉, ...

  3. 4.client、offset、scroll系列

    client.offset.scroll系列 他们的作用主要与计算盒模型.盒子的偏移量和滚动有关 clientTop 内容区域到边框顶部的距离 ,说白了,就是边框的高度 clientLeft 内容区域 ...

  4. JavaScript-client、offset、scroll、定时器

    client offset scroll client.offset.scroll系列 他们的作用主要与计算盒模型,盒子的偏移量和滚动有关 clientTop 内容区域到边框顶部的距离, 说白了, 就 ...

  5. JavaScript学习笔记5 之 计时器 & scroll、offset、client系列属性 & 图片无缝滚动

    一.计时器 setInterval ( 函数/名称 , 毫秒数 )表示每经过一定的毫秒后,执行一次相应的函数(重复) setTimeout ( 函数/名称 , 毫秒数 ) 表示经过一定的毫秒后,只执行 ...

  6. 区别client、offset、scroll系列以及event的几个距离属性

    element元素结点属性 一. offset系列 1.offsetWidth 和offsetHeight element.offsetWidth是一个只读属性,它包括了: css width + p ...

  7. python 全栈开发,Day54(关于DOM操作的相关案例,JS中的面向对象,定时器,BOM,client、offset、scroll系列)

    04-jQuery的属性操作 jquery的属性操作模块分为四个部分:html属性操作,dom属性操作,类样式操作和值操作 html属性操作:是对html文档中的属性进行读取,设置和移除操作.比如at ...

  8. 各种位置和高度计算:.position()、.offset()、.outerHeight()、.scrollTop、.scrollHeight、.clientHeight

    1..position()和.offset() jquery的.position()获取相对于最近的position为relative或absolute的父元素的偏移,返回.position().le ...

  9. 差别client、offset、scroll系列以及event的几个距离属性

    element元素结点属性 一. offset系列 1.offsetWidth 和offsetHeight element.offsetWidth是一个仅仅读属性,它包含了: css width + ...

随机推荐

  1. 问题007:JDK版本与JRE版本不同导致java.exe执行类文件错误 java.lang.UnsupportedClassVersionError错误

    版本不同的原因是,Windows 系统之前安装了JRE 是别的版本的 解决方法,将其卸载,卸载后可以正常使用,不再错误提示.

  2. python变量声明及简单数据类型

    一.python声明变量 变量的命名和使用 # 在Python中使用变量时,需要遵守一些规则和指南. # 违反这些规则将引发错误,而指南旨在让你编写的代码更容易阅读和理解.请务必牢记下述有关变量的规则 ...

  3. 第39-43课 thinkphp5完成商品会员价格功能(后置勾子afterInsert)

    目录 功能一:利用后置勾子,处理好商品主键id,会员的价格,再插入member_price表里. 要实现的功能: 思路: html里 控制器里 模型里的后置勾子afterInsert() 功能二:利用 ...

  4. win10桌面显示我的电脑

    1.桌面单击右键菜单栏,选中单击个性化 2.选择主题->桌面图标设置 3.勾选需要显示或不显示的图标

  5. 在virtualBox中打开vdi(转载)

    在VirtualBox中启动“新建虚拟机”向导.第一步,输入名称“ubuntu”,选择系统类型为“Linux 2.6”.第二步,内存大小默认是256MB,不变.第三步,虚拟硬盘,点击按钮“现有”,在新 ...

  6. 矩阵乘法在hadoop的实现

    先随机生成一个矩阵,矩阵的行数与列数由用户输入: #!/bin/bashfor i in `seq 1 $1`do for j in `seq 1 $2` do s=$((RANDOM%100)) e ...

  7. 部署 Windows PowerShell Web 访问

    部署 Windows PowerShell Web 访问 适用对象:Windows Server 2012, Windows Server 2012 R2 Windows PowerShell® We ...

  8. CLOUDSTACK FOR HYPER-V

    原文地址:http://zhu.vn/archives/1040 我这里是内网测试环境,宿主机为Server 2012R2 ,虚拟化技术为HYPER-V,域环境来的(不是域环境玩不了). 先给宿主机安 ...

  9. Effictive C++ 学习记录

    这是前段时间看的书,整理到这里吧,以后查看也方便. 这些条款需要反复查看. 条款01:视C++为一个语言联邦 条款02:尽量用const.enum.inline替换#define 条款03:尽可能的使 ...

  10. Leetcode 565.数组嵌套

    数组嵌套 索引从0开始长度为N的数组A,包含0到N - 1的所有整数.找到并返回最大的集合S,S[i] = {A[i], A[A[i]], A[A[A[i]]], ... }且遵守以下的规则. 假设选 ...