获取元素大小和位置的方式

一、直接获取元素样式属性值 – element.style.width

console.log(div.style.width); // 500px
console.log(parseInt(div.style.width)); // 500
console.log(typeof (div.style.width)); // string

二、Offset 偏移量

offsetWidth = width + padding + border
offsetHeight = height + padding + border

console.log(div.offsetWidth); // 560 (500 + 20 + 20 + 10 + 10)
console.log(typeof (div.offsetWidth)); // number

offsetLeft : 当前元素相对于其定位父元素的水平偏移量
offsetTop : 当前元素相对于其定位父元素的垂直偏移量

在这里插入图片描述

在父盒子有定位的情况下,offsetLeft == parseInt(style.left)。注意:后者只识别行内样式!!!

三、offsetParent :获取当前元素的定位父元素

如果当前元素的父元素,有CSS定位那么 offsetParent 获取的是最近的那个父元素

如果当前元素的父元素,没有CSS定位,那么 offsetParent 获取的是 body。

注意:fixed 的父级是窗口,返回值是 null

四、offsetLeftstyle.left 区别

offsetLeft 可以返回无定位父元素的偏移量。如果父元素中没有定位,则以 body 为准。

style.left 只能获取行内样式,如果父元素中都没有设置定位,则返回空字符串。

offsetTop 返回的是数字,而 style.top 返回的是字符串,而且还带有单位px

div.offsetLeft = 100;
div.style.left = '100px';

offsetLeftoffsetTop 只读,而 style.leftstyle.top 可读可写

总结:一般用 offsetLeftoffsetTop 获取值,用 style.leftstyle.top 赋值

  • style.left: 只能获取行内样式,获取的值可能为空,容易出现 NaN
  • offsetLeft: 获取值特别方便,而且是现成的 number ,计算比较方便。它只是读的,不能赋值。

三、Client

clientWidth : 获取元素的可见宽度(width + padding)
clientHeight : 获取元素的可见高度(height + padding)

注意

clientWidthclientHeight 属性是只读的,不可修改
clientWidthclientHeight 的值都是不带 px 的,返回的都是一个数字,可以直接进行计算。

console.log(div.clientWidth); // 540 (500 + 20 + 20)
console.log(typeof (div.clientWidth)); // number

但是加了滚动条就不一样了PC 端浏览器滚动条的默认大小为 17px

console.log(div.clientWidth); // 523 (540 - 17)

在这里插入图片描述

clientLeftclientTop

实际上就是盒子上的 border 宽度

console.log(typeof (div.clientLeft) + ':' + div.clientLeft); // number : 10

eventclientXclientY

  • e.clientX : 鼠标距离可视区域左侧距离。
  • e.clientY : 鼠标距离可视区域上侧距离。

四、Scroll 滚动

window.onscroll() 方法

当鼠标滚轮滚动网页的时候,会触发 window.onscroll() 方法。所以可以用来做滚动监听。
在这里插入图片描述

加上滚动条之后

console.log(div.scrollWidth); // 523

scrollTop : 获取垂直方向上滚动的距离
scrollLeft : 获取水平方向上滚动的距离

注意:

当某个元素满足 scrollHeight - scrollTop === clientHeight 时,说明垂直滚动条到底了。

当某个元素满足 scrollWidth - scrollLeft === clientWidth 时,说明水平滚动条到底了。

上面两个可以用来判断用户是否滑到底了,如果滑到底了,才进行接下来的表单操作

除了 style , crollTop , scrollLeft 是可读的,其他都是只读

五、获取 html 文档的方式

获取 html / head / title / body 标签的方法如下:

  • document.documentElement — 获取 html 标签
  • document.head — 获取 head 标签
  • document.title — 获取网页标题
  • document.body — 获取 body 标签

document.documentElement 表示文档的 html 标签。也即是说,基本结构当中的 html 标签是通过 document.documentElement 访问的,并不是通过 document.html 去访问的。

六、offset / scroll / client 的区别

  • offsetWidth = width + padding + border
  • offsetHeight = height + padding + border
  • scrollWidth = 内容宽度(不包含 border)
  • scrollHeight = 内容高度(不包含 border)
  • clientWidth = width + padding
  • clientHeight = height + padding

offsetTop / offsetLeft:

  • 调用者:任意元素。(盒子为主)
  • 作用:距离父级盒子中带有定位的距离

scrollTop / scrollLeft

  • 调用者:document.body.scrollTop(window调用)(盒子也可以调用,但必须有滚动条)
  • 作用:浏览器无法显示的部分(被卷去的部分)

clientY / clientX

调用者:event

作用:鼠标距离浏览器可视区域的距离(左、上)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/556112.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

normalize函数_Pandas 数据处理(一) —— 几个简单函数掌握!

对于 Pandas, 接触过 Python 数据处理的小伙伴们都应该挺熟悉的,做数据处理不可或缺的一个程序包,最大的特点高效,本篇文章将通过案例介绍一下 Pandas 的一些基础使用!1,读入数据大部分数据都可以用 read_c…

Java Collections.emptyList() 方法的使用及注意事项

Java Collections.emptyList方法的使用及注意事项 一、emptyList() 作用:返回一个空的List(使用前提是不会再对返回的list进行增加和删除操作);好处: 1. new ArrayList()创建时有初始大小,占用内存&#…

Java集合工具类的一些坑,Arrays.asList()、Collection.toArray()...

Arrays.asList() 使用指南 最近使用Arrays.asList()遇到了一些坑,然后在网上看到这篇文章:Java Array to List Examples 感觉挺不错的,但是还不是特别全面。所以,自己对于这块小知识点进行了简单的总结。 简介 Arrays.asList()…

什么是 NIO? NIO 和 BIO、AIO 之间的区别是什么?NIO主要用来解决什么问题?

1 BIO,NIO,AIO都有什么区别,NIO的原理是什么? BIO BIO:传统的网络通讯模型,就是BIO,同步阻塞IO, 其实就是服务端创建一个ServerSocket, 然后就是客户端用一个Socket去连…

关于页面配色

一、互补色 当两个颜色恰好在色环的两端时,这两个颜色叫做补色。补色搭配能形成强列的对比效果 在线配色工具地址 文字背景色和文字颜色互为补色,文字会很难看清,那么就只使用一种颜色作为主要颜色,其补色用来装点页面 比如&…

一次性说清楚秒验(本机号码一键登录)基本原理、优势、场景、交互过程和常见的问题

一、 关于秒验(一键登录)基本原理 秒验(一键登录)产品整合了三大运营商特有的数据网关认证能力,升级短信验证码体验,应用于用户注册、登陆、支付、安全校验等场景,可实现用户无感知校验&#x…

三大运营商实现本机号码一键登录原理与应用

很多APP的目前都支持“本机号码一键登录”功能。本机号码一键登录是基于运营商独有网关认证能力推出的账号认证产品。用户只需一键授权,即可实现以本机号码注册/登录,相比先前的短信验证码流程体验更优。 目前市面上有很多厂商提供三网验证的服务&#…

部署到gcp_剖析大数据公司为什么选择 GCP?

文章来源:加米谷大数据假如L 是一家大数据公司。下面我们的文章将围绕L展开分析。很多公司拥有大数据。每天早餐之前,健壮的日志框架就已经生成了 PB 级别的日志,并以防万一将这些数据长期保存在了亚马逊的 S3 上。还有一些公司会使用他们自己…

Redis缓存那点破事 , 绝杀面试官 25 问

转载:https://blog.csdn.net/itomge/article/details/122118060 精彩文章汇总 GitHub https://github.com/aalansehaiyang/technology-talk ,Star 12K ,汇总java生态圈常用技术框架、开源中间件,系统架构、数据库、大公司架构案例…

Mysql的select in会自动过滤重复的数据

Mysql的select in会自动过滤重复的数据 默认使用 SELECT 语句; 当加上in范围后,结果如下图: in范围内的数据,如果有重复的,只会选择第一个数据。 所以如果不是直接使用SQL语句来查询,而是在代码中来查询…

java.sql.SQLIntegrityConstraintViolationException: Cannot add or update a child row: a foreign key c

错误原图: 错误分析:外键约束失败导致插入数据有误 解决问题:检查被关联的外键字段值,在原表中是否有对应的值,添加时外键的值在原表(外键关联的表)中一定要有该值,没有的值添加报错…

MySql 清空、删除、截断表时1701错误

项目已经进行一段时间,整体的开发工作已经完成。接下来要进入综合测试阶段,所以想要将数据清理一下,然后报了1701错误,由错误提示得知是外键约束的问题 解决办法:关闭外键约束->清空表、截断表->启动外键约束。…

编辑流程图_流程图不会绘制?一分钟手把手教你学会,超简单

我们每天的日常工作非常繁忙,经常被日常的事务性工作淹没,而忽略掉我们工作的流程是否正确,我们的方向是否正确。如果流程、方向错了,再努力都是没有用的。要确保努力与付出是有价值的,就必须确保前进方向是正确的&…

MVVM 模型

MVVM 模型 在实际代码中 <!--MVVM 模型&#xff1a;1. M: 模型(Model) : data 中的数据2. V: 视图(View) : 模板代码3. VM: 视图模型(ViewModel) : Vue 实例观察发现&#xff1a;1. data 中所有的属性&#xff0c;最后都出现在了 vm 身上2. vm 身上所有的属性 以及 Vue 原…

NAVICAT MYSQL 建表字段 默认值、EMPTY STRING、空白、NULL 的区别

Navicat mysql 建表字段 默认值、empty string、空白、NULL 的区别 总结在最后&#xff0c;没啥干货 简单测试了4种类型 bigint tinyint varchar char 单引号 ‘’ 双引号 “” 自定义的默认值 如&#xff1a; 未知的姓名 新建一张用户表 CREATE TABLE user (id bigint(20…

如何将vue项目打包为.apk文件

说明&#xff1a;使用Vue.js开发完毕的app一般不作处理的话&#xff0c;就只能在浏览器上做为Webapp使用。如果需要将它安装到安卓手机上就需要打包为.apk文件了。 前提&#xff1a;安装HBuilderX 具体步骤&#xff1a; 1.在vue项目中找到config/build.js 2.找到build下的a…

linux 快照

一、快照管理器 二、选择保存的快照 — 出错了方便回去

工作琐事太多怎么办_东莞夫妻感情不合怎么办 东莞专业离婚咨询

东莞夫妻感情不合怎么办 东莞专业离婚咨询工作中的琐事影响感情交流&#xff0c;当然什么事也没有但我却打他&#xff0c;还有一些行刑人在旁边站着。行为泼辣得不到观众的好感。对当时的一些知识和政界发生。只记得内容是希望他好自为之&#xff0c;生活中她是位的。苏菲宗派里…

23种经典设计模式都有哪些,如何分类?Java设计模式相关面试

23种经典设计模式都有哪些&#xff0c;如何分类&#xff1f; 23种经典设计模式都有哪些&#xff0c;如何分类&#xff1f; java常用的设计模式&#xff1f;说明工厂模式 Java 中的23 种设计模式&#xff1a; Factory&#xff08;工厂模式&#xff09;&#xff0c; Builder&am…

五大常用算法学习笔记

一、分治算法&#xff1a;快速排序、归并排序、大整数乘法、二分查找、递归&#xff08;汉诺塔&#xff09; 基本概念&#xff1a;把一个复杂的问题分成若干个相同或相似的子问题&#xff0c;再把子问题分成更小的子问题… &#xff0c; 知道最后子问题可以简单的直接求解&…