1.1 offset概述

offset翻译过来,就是偏移量,我们使用offset系列相关属性,可以动态的得到该元素的位置(偏移)、大小等。

  • 获取元素距离带有定位父元素的位置。
  • 获得元素自身的大小(宽度高度)。
  • 注意: 返回的数值都不带单位。

offset系列常用属性:

offset系列属性 作用
element.offsetParent 返回作为该元素带有定位的父级,如果父级都没有定位,则返回body
element.offsetTop 返回元素相对带有定位父元素上方的偏移
element.offsetLeft 返回元素相对带有定位父元素左边框的偏移
element.offsetWidth 返回自身包括padding、边框、内容区的宽度,返回数值不带单位
element.offsetHeight 返回自身包括padding、边框、内容区的高度,返回数值不带单位

1.2 offset与style区别

offset style
offset可以得到任意样式表中的样式值 style只能得到行内样式表的样式值
offset系列获得的数值是没有单位的 style.width获得的是带有单位的字符串
offsetWIdth包含padding+border+width style.width获得不包含padding和border的值
offsetWidth等属性是只读属性,只能获取不能赋值 style.width是可读写属性,可以获取也可以赋值
所以,我们想要获取元素大小位置,用offset更合适 所以,我么想要给元素更改值,则需要用style改变

1.3 拖拽模态框

案例分析:

1.点击弹出层,模态框和遮罩层就会显示出来display:block;

2.点击关闭按钮,模态框和遮罩层就会隐藏起来display:none;

3.在页面中拖拽的原理:鼠标按下并且移动,之后松开鼠标;

4.触发事件是鼠标按下mousedown,鼠标移动mousemove,鼠标松开mouseup;

5.拖拽过程:鼠标移动过程中,获得最新的值赋值给模态框的left和top值,这样模态框就可以跟着鼠标走了;

6.鼠标按下触发的事件源是最上面一行,就是id为title

7.鼠标的坐标减去鼠标在盒子里的坐标,才是模态框真正的位置。

 1 <div class="login-header"><a id="link" href="javascript:;">点击,弹出登录框</a></div>
2 <div id="login" class="login">
3 <div id="title" class="login-title">登录会员
4 <span><a id="closeBtn" href="javascript:void(0);" class="close-login">关闭</a></span>
5 </div>
6 <div class="login-input-content">
7 <div class="login-input">
8 <label>用户名:</label>
9 <input type="text" placeholder="请输入用户名" name="info[username]" id="username" class="list-input">
10 </div>
11 <div class="login-input">
12 <label>登录密码:</label>
13 <input type="password" placeholder="请输入登录密码" name="info[password]" id="password" class="list-input">
14 </div>
15 </div>
16 <div id="loginBtn" class="login-button"><a href="javascript:void(0);" id="login-button-submit">登录会员</a></div>
17 </div>
18 <!-- 遮盖层 -->
19 <div id="bg" class="login-bg"></div>
20
21 <script>
22 // 获取元素
23 var login = document.querySelector('.login');
24 var mask = document.querySelector('.login-bg');
25 var link = document.querySelector('#link');
26 var closeBtn = document.querySelector('#closeBtn');
27 var title = document.querySelector('#title');
28 // 2.点击弹出层这个链接link,让mask和login显示出来
29 link.addEventListener('click', function(){
30 mask.style.display = 'block';
31 login.style.display = 'block';
32 });
33 // 3. 点击closeBtn就隐藏mask和login
34 closeBtn.addEventListener('click', function() {
35 mask.style.display = 'none';
36 login.style.display = 'none';
37 });
38 // 4.开始拖拽
39 // (1)当我们鼠标按下,就获得鼠标在盒子里的坐标
40 title.addEventListener('mousedown', function(e){
41 var x = e.pageX - login.offsetLeft;
42 var y = e.pageY - login.offsetTop;
43 // (2)鼠标移动的时候,把鼠标在页面的坐标,减去鼠标在盒子里的坐标,就是模态框的left和top
44 document.addEventListener('mousemove', move);
45 function move(e) {
46 login.style.left = e.pageX - x + 'px';
47 login.style.top = e.pageY - y + 'px';
48 };
49 // 鼠标弹起,就让鼠标移动事件移除
50 document.addEventListener('mouseup', function() {
51 document.removeEventListener('mousemove' , move)
52 })
53 })
54 </script>

京东放大镜效果:

 1 window.addEventListener('load', function() {
2 var preview_img = document.querySelector('.preview_img');
3 var mask = document.querySelector('.mask');
4 var big = document.querySelector('.big');
5 // 1.当我们鼠标经过preview_img就显示和隐藏mask遮罩层和big大盒子
6 preview_img.addEventListener('mouseover', function() {
7 mask.style.display = 'block';
8 big.style.display = 'block';
9 });
10 preview_img.addEventListener('mouseout', function() {
11 mask.style.display = 'none';
12 big.style.display = 'none';
13 });
14 // 2.鼠标移动的时候,让黄色盒子跟着鼠标来走
15 preview_img.addEventListener('mousemove', function(e) {
16 // (1).先计算出鼠标在盒子里的坐标
17 var x = e.pageX - this.offsetLeft;
18 var y = e.pageY - this.offsetTop;
19 // (2).减去盒子高度 300的一半 是150就是我们mask的最终 left和top值了
20 // (3).我们mask移动的距离
21 var maskX = x - mask.offsetWidth / 2;
22 var maskY = y - mask.offsetHeight / 2;
23 // (4). 如果x坐标小于0, 就让他停在0的位置
24 // 遮罩层的最大移动距离
25 var maskMax = preview_img.offsetWidth - mask.offsetWidth;
26 if(maskX <= 0) {
27 maskX = 0;
28 } else if (maskX >= maskMax) {
29 maskX = maskMax;
30 }
31 if (maskY <= 0) {
32 maskY = 0;
33 } else if (maskY >= maskMax) {
34 maskY = maskMax;
35 }
36 mask.style.left = maskX + 'px';
37 mask.style.top = maskY + 'px';
38 // 大图片的移动距离 = 遮挡层移动距离 * 大图片最大移动距离 / 遮挡层的最大移动距离
39 var bigImg = document.querySelector('.bigImg');
40 // 大图片的移动距离
41 var bigMax = bigImg.offsetHeight - big.offsetWidth;
42 // 大图片的移动距离
43 var bigX = maskX * bigMax / maskMax;
44 var bigY = maskY * bigMax / maskMax;
45 bigImg.style.left = -bigX + 'px';
46 bigImg.style.top = -bigY + 'px';
47 })
48 })

元素偏移量offset系列的更多相关文章

  1. 元素偏移量 offset 系列

    offset 概述 offset翻译过来就是偏移量,我们使用offset系列相关属性可以动态的得到该元素的位置(偏移).大小等. 获得元素距离带有定位父元素的位置 获得元素自身的大小(宽度高度) 注意 ...

  2. 模态框拖拽案例分析--元素偏移量 offset 系列

    弹出框,我们也称为模态框. 模态框拖拽案例分析: (1)点击弹出层, 会弹出模态框, 并且显示灰色半透明的遮挡层. (2)点击关闭按钮,可以关闭模态框,并且同时关闭灰色半透明遮挡层. (3)鼠标放到模 ...

  3. jq获取元素偏移量offset()

    解释: 1 获取匹配元素在当前视口的相对偏移. 2 返回的对象包含两个整型属性:top 和 left demo1: 获取top与left var aaa = $(".aaa "); ...

  4. jacascript 偏移量offset、客户区client

    前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! 偏移量 偏移量(offset dimension)是 javascript 中的一个重要的概念.涉及到偏移 ...

  5. offset系列,client系列,scroll系列回顾

    一 scroll系列属性      ——滚动

  6. offset系列、scroll系列与client系列

    offset系列: offsetLeft:获取元素距离最左边的距离,自身的margin包括在内,不包括自身的border offsetTop:获取元素距离最上边的距离,自身的margin包括在内,不包 ...

  7. client系列、offset系列、scroll系列

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

  8. 009 轮播图,offset系列

    关于使用JS做轮播图,使用一个章节进行笔迹. 一:简单轮播图 1.程序 <!DOCTYPE html> <html lang="en"> <head& ...

  9. offset系列属性

    offset系列:获取元素的相关的样式属性的值 offsetwidth:获取元素的宽 offsetheight:获取元素的高 offsetleft:获取元素距离左边位置的值 offsettop;获取元 ...

  10. js offset系列属性

    offsetParent:返回该元素有定位的父级,如果父级都没有定位则返回body offsetTop:返回元素相对父级(带有定位的父级)上方的偏移 offsetLeft:返回元素相对父级(带有定位的 ...

随机推荐

  1. AtCoder_abc326

    T1 2UP3DOWN 简单的if判断,做题一分钟,翻译十分钟... 代码: #include<bits/stdc++.h> using namespace std; int main() ...

  2. drf实战和源码剖析----学习笔记1

    学自:bilibili武沛齐老师. 武老师讲课:清晰,连贯,实用,透彻,真乃名师! # 1. 什么是前后端分离 - 不分离,主要用于后台系统(CRUD)和用户量上的情况,开发起来代价小- 分离,面向用 ...

  3. 从零开始用 Axios 请求后端接口

    对于前端同学来说,请求后端接口是一个非常通用的东西.在十几年前的时候,我们还用 Ajax 去请求后端接口.但在 2023 年的今天,很多框架都很成熟了,我们有了更加快捷的方式 -- Axios 框架. ...

  4. Scrapy-settings.py常规配置

    # Scrapy settings for scrapy_demo project # # For simplicity, this file contains only settings consi ...

  5. 【内核】kernel 热升级-1:kexec 机制

    内核热升级是指,预先准备好需要升级的内核镜像文件,在秒级时间内,完成内核切换,追求用户服务进程无感知. 欧拉操作系统提供了一套比较成熟的解决方案,该解决方案提供了用户态程序和内核态程序两部分: kex ...

  6. 数字孪生技术结合GIS系统能在农业领域作出什么改变?

    数字孪生技术和地理信息系统(GIS)是两个独立但高度互补的领域,它们的结合在农业领域具有巨大的潜力,可以带来巨大的改变.在这篇文章中,我们将讨论数字孪生技术和GIS系统如何协同作用,为农业带来创新和可 ...

  7. 【Python】【OpenCV】定位条形码(二)moments和HuMoments

    根据上一篇博客可知,单纯的通过求取最大面积而进行定位的局限性,因此我们接下来将通过cv2.moments()和cv2.HuMoments()这两个方法来在更复杂的环境中去找到我们的目标区域. cv2. ...

  8. 神经网络优化篇:详解归一化输入(Normalizing inputs)

    归一化输入 训练神经网络,其中一个加速训练的方法就是归一化输入.假设一个训练集有两个特征,输入特征为2维,归一化需要两个步骤: 零均值 归一化方差: 希望无论是训练集和测试集都是通过相同的\(μ\)和 ...

  9. Linux云服务器购买,学习

    购买云服务器的初衷 作为一名自动化测试工程师,不能仅限于掌握工作上的业务和代码,业余时间需要找点开源项目来练习性能.接口.UI自动化. 云服务器购买 https://www.aliyun.com/ 我 ...

  10. 初探 Linux Cgroups:资源控制的奇妙世界

    Cgroups 是 linux 内核提供的功能,由于牵涉的概念比较多,所以不太容易理解.本文试图通过简单的描述和 Demo 帮助大家理解 Cgroups . 如果你对云原生技术充满好奇,想要深入了解更 ...