一.元素尺寸信息

元素.offsetWidth: 元素的外宽高 width + padding + border

元素.offsetHeight: 元素的外宽高 height + padding + border

元素.clientWidth: 元素的内宽高 width + padding

元素.clientHeight: 元素的内宽高 height+ padding

元素.offsetLeft: 相对于定位父元素左则的距离

元素.offsetTop: 相对于定位父元素顶部的距离

window.innerWidth: 浏览器的宽高(包含滚动条)

window.innerHeight: 浏览器显示窗口的当前高(包含滚动条)

document.documentElement.clientWidth || document.body.clientWidth

浏览器的宽高(不包含滚动条)

浏览器显示窗口的内容区宽高

document.documentElement.scrollWidth || document.body.scrollHidth

浏览器的滑动条距离;

document.document.scrollTop || document.body.scrollTop 滚动条滚动距离

#二.事件对象相关位置方法

鼠标距离盒子左上的位置: e.offsetX e.offsetY

鼠标相对于浏览器的位置: e.clientX e.clientY

鼠标相对于页面的位置: e.pageX e.pageY

#三.案例

#1. 单个盒子拖拽

效果图:

img

功能思路分析:

按下盒子,盒子才能拖。盒子跟随鼠标移动,盒子移动即修改盒子的left和top。松开鼠标停止拖拽。

功能一: 鼠标按下开起拖拽

\1. 给要拖拽的元素绑定鼠标按下事件( mousedown )

\2. 记录鼠标到盒子的距离**(e.offsetX e.offsetY)**

\3. 开启控制盒子移动的变量 ( flag = true )

功能二: 鼠标移动盒子移动

\1. 给document绑定**鼠标移动事件 (mousemove),**开关变量为真时移动盒子

\2. 盒子位置 = 鼠标到页面的距离( e.pageX ) - 鼠标到盒子的距离( pos.x )

\3. 范围判断: 最小为0; 最大 = 页面的宽 - 盒子的宽

\4. 修改盒子的left 和 top

功能三: 鼠标松开停止拖拽

松开鼠标时关闭开关变量

#2. 图标回收站

效果图:

功能思路分析:

功能一:图标拖拽

\1. 多个图标通过事件委托绑定鼠标按下事件

\2. 鼠标按下开启拖拽开关( flag = true ),记录鼠标到图标的距离(e.offsetX e.offsetY ),记录事件源(e.target) 。

\3. 图标跟随鼠标移动,给document绑定鼠标移动事件mousemove,当开关变量为真时移动盒子。

功能二:图标回收

\1. 当鼠标松开时,关闭拖拽开关

\2. 边界判断: 图标进入回收站则删除图标,并计数

#四.今日小结

1.元素的外宽高: 元素.offsetWidth 元素.offsetHeight

2.元素的内宽高: 元素.clientWidth 元素.clientHeight

3.元素相对于定位父元素距离: 元素.offsetLeft 元素.offsetTop

4.鼠标相对于元素位置: e.offsetX e.offsetY

5.鼠标相对于窗口位置: e.clientX e.clientY

6.鼠标相对于页面位置: e.pageX e.pageY

7.浏览器窗口大小:

document.documentElement.clientWidth || document.body.clientWidth

8.滚动距离:

document.documentElement.scrollTop || document.body.scrollTop

#五.作业 -- 成绩分类

效果图:

img

功能思路分析:

1. 成绩标签拖拽

\1. 利用事件委托将左侧的成绩标签实现拖拽

\2. 给成绩大盒子绑定鼠标按下事件,判断事件源

\3. 给document绑定鼠标移动事件,成绩标签跟随鼠标移动

2. 指定边界判断

\1. 给document绑定鼠标松开事件,松开时判断鼠标位置

\2. 当鼠标进入成才盒子,再判断成绩,合格则放入;当鼠标进入不成才盒子,不合格则放入。否则回到原地

js下 Day10、尺寸位置属性的更多相关文章

  1. js,jq获取元素位置属性及兼容性写法

    网页被卷起来的高度/宽度 document.documentElement.scrolltop //火狐 和 其他浏览器 document.body.scrolltop   //ie,谷歌浏览器和没有 ...

  2. three.js 相机camera位置属性设置详解

    开始很懵逼,完全不能理解,有个position,还要up和lookAt干嘛. [黑人问号脸❓❓❓] 既然是位置属性不明白,那默认其它属性都懂了. 上坐标轴: 先来第一个position属性,可以设置x ...

  3. JS Div滚动,下拉框添加属性,年月日下拉条

    创建某一下拉菜单的项: str = str+"<option value='"+i+"'>"+i+"</option>&quo ...

  4. css中overflow:hidden的属性 可能会导致js下拉菜单无法显示

    css中overflow:hidden属性导致ExtJS中无法显示下拉滚动条 overflow属性: visible 默认.内容不会被修剪,会呈现在元素之外. hidden 内容会被修剪,但是浏览器不 ...

  5. Swift下的基于UIView的位置属性扩展

    一个比较简单能满足大部分需求的extensin,如下: swift 的基于UIView的位置属性 包含: 上下左右:left.right.top.botom 高宽:height.width 中心点:c ...

  6. js中scrollLeft、scrollWidth、offsetTop等相关位置属性的理解(转)

    1.常见的事件位置属性 e.pageX——相对整个页面的坐标 注意:IE6.IE7.IE8无该属性 e.layerX——相对当前坐标系的border左上角开始的坐标 注意:在opera.IE6.IE7 ...

  7. Python全栈开发之路 【第十七篇】:jQuery的位置属性、事件及案例

    位置属性 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <titl ...

  8. JQuery框架2.位置属性|筛选方法|事件

    1.位置属性 jquery的css position获取匹配元素相对父元素的偏移位置:offset获取匹配元素在当前视口的相对偏移,返回的对象包含两个整型属性:top 和 left $("p ...

  9. 前端开发之jQuery位置属性和筛选方法

    主要内容: 1.jQuery的位置属性及实例 (1)位置属性 (2)实例 --- 仿淘宝导航栏 2.jQuery的筛选方法及实例 (1)筛选方法 (2)实例一:嵌套选项卡 (3)实例二:小米官网滑动 ...

随机推荐

  1. vue项目中echarts属性总结

    <div id="echarts" style="width: 600px;height: 400px;margin-top: 100px;margin-left: ...

  2. 做了两年java,这些高性能高可用高并发的技术架构你都知道吗?

    前言 每一个模式描述了一个在我们周围不断重复发生的问题及该问题解决方案的核心.这样,你就能一次又一次地使用该方案而不必做重复工作. 所谓网站架构模式即为了解决大型网站面临的高并发访问.海量数据.高可靠 ...

  3. Camtasia快捷键大全

    Camtasia是一款专业屏幕录制软件,它能在任何颜色模式下轻松地记录屏幕动作,另外它还具有即时播放和编辑压缩的功能.在生活上应用范围相当的广泛.在实际运用中如果能了解到相关的快捷键知识,相信是一定程 ...

  4. mathtype样式系统使用技巧-通过样式定义来更改方程中的字体

    本教程中,我们主要介绍MathType Desktop的样式系统.演示如何通过更改样式定义来更改方程中的字体.通过样式可以快速轻松地实现我们所需的公式格式,并统一所有公式的样式. 我们以如下公式来作为 ...

  5. Mac中的格式转换如何用读写工具Tuxera NTFS完成

    Tuxera NTFS for Mac是一款专门为Mac用户提供的NTFS驱动软件,它不仅可以进行磁盘文件的访问.编辑.传输和存储,还可以对硬盘进行维修检查以及修复. 今天小编就给大家简单介绍一下Tu ...

  6. js 时间日期与时间戳之间转换

    1 1.将时间(2017-08-10)转换时间戳 2 var startTime = '2017-08-10'; 3 var startdate = new Date(Date.parse(start ...

  7. Leetcode 周赛#202 题解

    本周的周赛题目质量不是很高,因此只给出最后两题题解(懒). 1552 两球之间的磁力 #二分答案 题目链接 题意 有n个空篮子,第i个篮子位置为position[i],现希望将m个球放到这些空篮子,使 ...

  8. JZOJ2020年8月12日提高组反思

    JZOJ2020年8月12日提高组反思 真·难亿一点点 T1 题目长并附带伤害-- 暴力搜 对于字符串,我选择\(Pascal\) T2 概率问题,再见 T3 样例没懂,再见 T4 有史以来见过的条件 ...

  9. redis的配置文件redis.conf常用配置

    参数说明redis.conf 配置项说明如下:1. Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程 daemonize no2. 当Redis以守护进程方式运行时 ...

  10. PyQt(Python+Qt)学习随笔:QDateEdit日期编辑部件和QTimeEdit时间编辑部件

    专栏:Python基础教程目录 专栏:使用PyQt开发图形界面Python应用 专栏:PyQt入门学习 老猿Python博文目录 老猿学5G博文目录 Designer输入部件中,Date Edit和T ...