在写实例理解scrollWidth,clientWidth,innearWidth,availWidth及offsetWidth等的时候,意外的又发现了margin值合并的问题,在这里同时记录下

1.偏移量的区别

  • html文件(自己写的示例)
<div id="root">
<div class="box">
<div class="content"></div>
</div>
</div>
  • css样式
<style>
body, html{
padding: 0;
margin: 0;
}
#root{
/*position: relative;*/
margin: 0 auto;
width: 1200px;
/*border: 1px solid black;*/
}
.box{
overflow: scroll;
margin: 5px;
padding: 20px;
width: 500px;
height: 600px;
border: 2px solid blueviolet;
/*box-sizing: border-box;*/
background: linear-gradient(to right, rgb(85, 181, 255), rgb(207, 224, 232));
}
.content{
width: 530px;
height: 600px;
}
</style>
  • 较多见的属性
clientWidth: 指可见区的宽度(网页,或者元素)
clientHeight: 指可见区的高度(网页,或者元素)
offsetWidth: 指元素的宽度(网页,或者元素)
offsetHeight: 指元素的高度(网页,或者元素)
scrollTop: 滚动条的滚动距离
scrollLeft: 滚动条的滚动距离
availWidth: 屏幕可用区宽度
availHeight: 屏幕可用区高度
  • script
<script>
(function() {
let elementName = document.getElementsByClassName('box')[0];
let elementContent = document.getElementsByClassName('content')[0]; /* offsetWidth为元素的宽度,返回数值,只读属性(可以读取css文件里的值,也可以读取内联样式里的值)
* 当box-sizing为content-box时,offsetWidth=(padding-left)+(padding-right)+(border-left)+(border-right)+width
* 当box-sizing为border-box时,offsetWidth=width
* 当元素本身未设置宽时,读取的是父元素的宽度减去元素本身设置的margin值
* */
let elementWidth = elementName.offsetWidth;
console.log(elementWidth); /* clientWidth为元素的宽度,返回数值,只读属性(可以读取css文件里的值,也可以读取内联样式里的值)
* 在元素未溢出时:
* 当box-sizing为content-box时,clientWidth=(padding-left)+(padding-right)+width
* 当box-sizing为border-box时,clientWidth=width-(border-left)-(border-right)
* 当元素本身未设置宽时,读取的是父元素的宽度减去元素本身设置的border值
* 元素溢出时(子元素宽度大于父元素宽度):
* clientWidth为除了边框及X、Y向滚动条的宽度(可视区)
* */
let elemClientWidth = elementName.clientWidth;
console.log(elemClientWidth); /* style.width为元素的宽度,返回字符串(包含单位),可读写
* 原样的输出内联style里设置的width值,必须显示的设置,否则为空
* */
let styleWidth = elementName.style.width;
console.log(styleWidth); /* scrollWidth为元素的宽度,返回数值(包含padding值,不包含边框宽度值)
* 当元素没有溢出时(子元素宽度小于父元素宽度):此时与clientWidth值一样
* 当元素溢出时:(溢出值=子元素offsetWidth-[父元素offsetWidth-(父padding-left)-(父border-left)])
* 当子元素box-sizing为content-box时,scrollWidth=子元素offsetWidth+(父padding-right)
* 当子元素box-sizing为border-box时,
* scrollWidth=子元素offsetWidth+(父padding-right)-(子border-left)-(子border-right)-(子padding-right)-(子padding-left)
* */
let elemScrollWidth = elementName.scrollWidth;
console.log(elemScrollWidth); /* offsetTop为元素的上外缘距离最近采用定位的父元素内壁的距离,返回数值,只读
* 如果父元素中没有采用定位的,则是获取元素的上外边缘距离文档对象内壁的距离
* 定位只能为position:relative,其他定位值获取的是文档对象内壁的距离
* */
let elemOffsetTop = elementName.offsetTop;
console.log(elemOffsetTop); /* offsetLeft为元素的左外缘距离最近采用定位的父元素内壁的距离,返回数值,只读
* 如果父元素中没有采用定位的,则是获取元素的左外边缘距离文档对象内壁的距离
* 定位只能为position:relative,其他定位值获取的是文档对象内壁的距离
* */
let elemOffsetLeft = elementName.offsetLeft;
console.log(elemOffsetLeft); /* scrollHeight为元素内容的实际高度
* 包括元素高度、内边距和溢出尺寸,不包括边框和外边距
* 无溢出的情况,与clientHeight相同
* */
let elemScrollHeight = elementName.scrollHeight;
console.log(elemScrollHeight); /* scrollTop可以获取或者设置对象的最顶部到对象所在当前窗口显示的范围内的顶边的距离
* 也就是元素滚动条被向下拉动的距离
* 返回数值,可读写
* */
let documentScrollTop = document.documentElement.scrollTop || document.body.scrollTop;
console.log(documentScrollTop); /* scrollLeft可以获取或者设置对象的最左边到对象在当前窗口显示的范围内的左边的距离
* 也就是元素被滚动条向左拉动的距离
* 返回数值,可读写
* */
let documentScrollLeft = document.documentElement.scrollLeft || document.body.scrollLeft;
console.log(documentScrollLeft); /* innerWidth窗口的文档显示区的宽度(不包含工具条与滚动条),返回一个数值 */
let windowInnerWidth = window.innerWidth;
console.log(windowInnerWidth); /* availWidth为浏览器屏幕的可用宽度,返回数值 */
let screenAvailWidth = screen.availWidth;
console.log(screenAvailWidth); /* clientWidth为可视区的宽度,不包含滚动条的宽度 */
let documentClientWidth = document.documentElement.clientWidth || document.body.clientWidth;
console.log(documentClientWidth); elementName.onmousemove = function(event) {
/* eventX为鼠标相对于浏览器有效区域(除去工具栏等非html文档的区域)左上角x轴的坐标,不随滚动条滚动而改变 */
let eventX = event.clientX;
console.log(eventX); /* pageX为鼠标相对于浏览器有效区域(除去工具栏等非html文档的区域)左上角x轴的坐标,随滚动条滚动而改变 */
let pageX = event.pageX;
console.log(pageX); /* screenX为鼠标相对于显示器屏幕左上角x轴的坐标 */
let screenX = event.screenX;
console.log(screenX); /* offsetX为鼠标相对于事件源左上角X轴的坐标 */
let offsetX = event.offsetX;
console.log(offsetX);
}
})()
</script>



  • 下面这个的话是我百度找的图片

这个图我感觉有点复杂的样子,

2.margin值合并的问题

  • 当两个垂直外边距相遇时,它们将形成一个外边距。合并的外边距的高度等于两个发生合并的外边距的高度中的较大者
  • 还有一种就是:当父元素没有设置内边距或边框,以及触发BFC时,如果子元素的值大于父元素时,它会带着父元素一起偏移,此时子元素是相对除了它父级之外的离它最近的元素偏移的
  • 解决方法的话,可以改变两者的margin值,或者对元素设置border、padding,或者形成BFC

3.关于BFC(块格式化上下文)

  • 内部的box会在垂直方向,一个接一个的放置
  • Box垂直方向的距离由margin决定,属于同一个bfc的两个相邻box的margin会发生重叠
  • 每个元素的margin box 的左边,与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此
  • Bfc的区域不会与float box重叠
  • Bfc就是页面上的一个隔离的独立的容器,容器里面的元素不会影响到外面的元素,反之也是如此
  • 计算bfc的高度时,浮动元素也会参与计算

4.形成bfc的条件

  • 浮动元素,float除none外的值
  • 绝对定位元素,position(absolute,flxed)
  • display:inline-block,table-cells,table-captions
  • overflow除了visible以外的值

正在努力学习中,若对你的学习有帮助,留下你的印记呗(点个赞咯^_^)

关于scroll,client,innear,avail,offset等的理解的更多相关文章

  1. JavaScript 特效之四大家族(offset/scroll/client/event)

      三大系列:offset.scroll.client 事件对象:event(事件被触动时,鼠标和键盘的状态)(通过属性控制)   三大系列都是以DOM元素节点的属性形式存在的. 类比访问关系,也是以 ...

  2. client系列、offset系列、scroll系列

    一.client系列 clientWidth/clientHeight    是我们设置的宽和高加上内边距(没有边框) clientLeft/clientTop 就是我们设置的边框值 二.offset ...

  3. offset / scroll / client Left / Top

    1.offsetHeight / Width (只读) offsetHeight:表示该元素在垂直方向占用的空间大小,包含元素的高度+上边框高度+下边框高度 offsetWidth:表示该元素在水平方 ...

  4. 三大家族,offset,scroll,client

    1.client 1.1主要成员 1.clientWidth 获取网页可视区域宽度(两种用法)    clientHeight 获取网页可视区域高度 (两张用法) 盒子调用: 指盒子本省 浏览器调用: ...

  5. offset,scroll,client系列

    offsetHeight: 元素高,height+border+paddingoffsetWidth: 元素宽,width+border+paddingoffsetTop: 距离offsetParen ...

  6. offset/client/scroll一些总结

    offset/client/scroll一些总结 1.offset 首先offset共有五个值 1.offsetParent 2.offsetTop 3.offsetLeft 4.offsetWidt ...

  7. 三大家族(offset、scroll、client)

    offset.scroll.client三大家族 offset家族 offsetWidth 与 offsetHeight offset 偏移 用于获取元素自身的位置和大小 offsetWidth和of ...

  8. 第52天:offset家族、scroll家族和client家族的区别

    一.offset家族 1.offsetWidth offsetHeight offsetLeft offsetTop offsetParent共同组成了offset家族,用来获取元素尺寸. offse ...

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

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

随机推荐

  1. springboot+dubbo基于zookeeper快速搭建一个demo

    由于小编是在windows环境下搭建的,故该示例均为在windows下操作,这里只是提供一个快速搭建思路,linux操作也基本上差不多. 首先本示例的dubbo是基于zookeeper发布订阅消息的, ...

  2. [DS+Algo] 001 先简单说说算法

    目录 1. 通俗地讲 2. 算法的五大特性 3. 众所周知的"公式" 4. 举个例子 例 1. 百钱买百鸡 1. 数学解法 2. C 的解法 3. Python 的解法 4. Ja ...

  3. STM32 晶振 系统时钟8MHZ和72Mhz的原因

    首先问题描述: 1.自己画的板子和淘宝买的最小系统板 系统时钟不一致,自己画的是8Mhz,HSE失败:最小系统板72Mhz 2.最小系统板在程序1运行仿真的时候,查看peripherals->P ...

  4. debian 安装java

    sudo apt-get update sudo apt-get install default-jre sudo apt-get install default-jdk

  5. P1219八皇后

    这个题是一道USACO的经典dfs,与我见面的时间起码七个月了. 放置n个皇后于n*n棋盘,他们不能互相吃(行,列,对角线),问有几种摆法?于是想到了dfs(自我认为有图的就不用DP).首先确定好了要 ...

  6. Java中的sort

    Java中对集合排序有两种方式 Comparable和Comparator public static <T> void sort(List<T> list); 将集合中的数据 ...

  7. linux安装mysql8(完整图文笔记)

    基本命令 安装 : yum install mysql-community-server 启动 : service mysqld start/restart 停止 : service mysqld s ...

  8. vuex辅助函数和vuex5个属性

    在上篇中,我们可以知道如果想要访问vuex.store中state中的数据,需要this.$store.state.属性名.显然这样访问数据写的代码很很不简洁的,辅助函数就是用来解决这个问题的. 1. ...

  9. git(github)配置密钥/私钥/SSH公钥)

    1.桌面右键 Git Bash Here 打开git命令行 2.ssh-keygen -t rsa -C "xxxxx@qq.com"(你的注册邮箱)enter 3.cd ~/.s ...

  10. web.xml文件头声明各个版本参考

    Servlet 3.1 Java EE 7 XML schema, namespace is http://xmlns.jcp.org/xml/ns/javaee/ <web-app xmlns ...