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

一、直接获取元素样式属性值 – 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,一经查实,立即删除!

相关文章

mybatis 取查询值_MyBatis-SELECT基本查询

1、返回一个LISTselect * from tbl_employee where last_name like #{lastName}2、将查询记录封装为一个Mapselect * from tbl_employee where id#{id}返回一条记录的map;key就是列名,值就是对应的值。3、多条记录封装为一个mapMapKey("id")pu…

ES6 里面的 class

ES5 对象的写法 let x 10,y 20;const obj {x: x,y: y,sum: function () {return this.x this.y;} };ES6 对象的写法 const obj {x,y,sum() {return this.x this.y;} };class 有点类似 java 的 class class Person { // 类名大写// 私有属性和方法 写在 construtor 里面…

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

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

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

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

git 生成多个patch_详解如何使用git 生成patch 和打入patch

平时我们在使用git 管理项目的时候,会遇到这样一种情况,那就是客户使用git 生成patch 给到我们,那我们就需要把客户给到patch 打入到我们的project ,基于这样一个场景,我把git 如何生成patch 和如何打入patch 做总结生…

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

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

python saltstack web_saltstack学习-8:web管理页面(halite)

安装halite方法一:失败,待查原因1、安装并启动salt-api yuminstall salt-api –yservice salt-api startchkconfig salt-api on2、安装halite及其依赖文件 yuminstall python-pip –ypipinstall --upgrade pippipinstall -U halitepipinstall cherrypypi…

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

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

关于页面配色

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

axure命令行_Axure变量详解

以前使用Axure只是停留在元件的布局和简单交互事件的设置,使用得非常肤浅,直到现在有时间静下心来重学Axure,才发现函数和变量的牛逼之处。以前在做较复杂交互时,为了实现一个效果吭哧吭哧写了一串命令,而往往函数和变…

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

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

php 基本语法

一、php 基本语法 <?php // echo | print 两种输出语句 echo 任何位置; print 任何位置; ?>二、注释 <?php // echo 任何位置; // 单行注释 /*多行注释*/ ?>三、变量声明 变量名以 $ 开始&#xff0c;后面跟变量的名字&#xff0c;区分大小写 <?php $x …

爬虫python能做游戏吗_一入爬虫深似海,从此游戏是路人!总结我的python爬虫学习笔记!...

1、基本抓取网页get方法post方法2、使用代理IP在开发爬虫过程中经常会遇到IP被封掉的情况&#xff0c;这时就需要用到代理IP&#xff1b;在urllib2包中有ProxyHandler类&#xff0c;通过此类可以设置代理访问网页&#xff0c;如下代码片段&#xff1a;3、Cookies处理cookies是某…

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

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

php 数据类型

七种数据类型&#xff1a; String / Integer / Float / Boolean / Array / Object / null 检测变量的数据类型和值 var_dump() 一、字符串 $x abc; var_dump($x); echo $x; // string abc二、整形 $x 1234; var_dump($x); echo $x; // int 1234三、浮点型 $x 1.1; var_d…

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

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

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

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

css 动画 - 这次不会忘记了

css 动画基本用法 div {animation-name: rainbow; /*动画名称*/animation-duration: 1s; /*这段动画开始到结束总共需要花费多长时间*/animation-fill-mode: forwards; /*动画在结束时元素的样式*/animation-iteration-count: infinite; /*动画运行几次&#xff1f;*/animatio…

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

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

vue初始

一、引入 Vue 文件 <script src"https://cdn.jsdelivr.net/npm/vue2.6.14/dist/vue.js"></script>二、定义一个容器 <!--root 容器里的代码称为 Vue模板;VueProject 实例和容器是一一对应的&#xff1b;真实开发中只有一个 Vue 实例&#xff0c;并且…