js下 Day10、尺寸位置属性
一.元素尺寸信息
元素.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. 单个盒子拖拽
效果图:
功能思路分析:
按下盒子,盒子才能拖。盒子跟随鼠标移动,盒子移动即修改盒子的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
#五.作业 -- 成绩分类
效果图:
功能思路分析:
1. 成绩标签拖拽
\1. 利用事件委托将左侧的成绩标签实现拖拽
\2. 给成绩大盒子绑定鼠标按下事件,判断事件源
\3. 给document绑定鼠标移动事件,成绩标签跟随鼠标移动
2. 指定边界判断
\1. 给document绑定鼠标松开事件,松开时判断鼠标位置
\2. 当鼠标进入成才盒子,再判断成绩,合格则放入;当鼠标进入不成才盒子,不合格则放入。否则回到原地
js下 Day10、尺寸位置属性的更多相关文章
- js,jq获取元素位置属性及兼容性写法
网页被卷起来的高度/宽度 document.documentElement.scrolltop //火狐 和 其他浏览器 document.body.scrolltop //ie,谷歌浏览器和没有 ...
- three.js 相机camera位置属性设置详解
开始很懵逼,完全不能理解,有个position,还要up和lookAt干嘛. [黑人问号脸❓❓❓] 既然是位置属性不明白,那默认其它属性都懂了. 上坐标轴: 先来第一个position属性,可以设置x ...
- JS Div滚动,下拉框添加属性,年月日下拉条
创建某一下拉菜单的项: str = str+"<option value='"+i+"'>"+i+"</option>&quo ...
- css中overflow:hidden的属性 可能会导致js下拉菜单无法显示
css中overflow:hidden属性导致ExtJS中无法显示下拉滚动条 overflow属性: visible 默认.内容不会被修剪,会呈现在元素之外. hidden 内容会被修剪,但是浏览器不 ...
- Swift下的基于UIView的位置属性扩展
一个比较简单能满足大部分需求的extensin,如下: swift 的基于UIView的位置属性 包含: 上下左右:left.right.top.botom 高宽:height.width 中心点:c ...
- js中scrollLeft、scrollWidth、offsetTop等相关位置属性的理解(转)
1.常见的事件位置属性 e.pageX——相对整个页面的坐标 注意:IE6.IE7.IE8无该属性 e.layerX——相对当前坐标系的border左上角开始的坐标 注意:在opera.IE6.IE7 ...
- Python全栈开发之路 【第十七篇】:jQuery的位置属性、事件及案例
位置属性 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <titl ...
- JQuery框架2.位置属性|筛选方法|事件
1.位置属性 jquery的css position获取匹配元素相对父元素的偏移位置:offset获取匹配元素在当前视口的相对偏移,返回的对象包含两个整型属性:top 和 left $("p ...
- 前端开发之jQuery位置属性和筛选方法
主要内容: 1.jQuery的位置属性及实例 (1)位置属性 (2)实例 --- 仿淘宝导航栏 2.jQuery的筛选方法及实例 (1)筛选方法 (2)实例一:嵌套选项卡 (3)实例二:小米官网滑动 ...
随机推荐
- 探究:nuget工具对不再使用的dll文件的处理策略
背景介绍 nuget是.net平台有效的包管理工具,相信每个C#开发者对它都不陌生. 本文我们来探究一下nuget对不再使用的dll文件的处理策略,分为如下2个场景: 场景A:包A1.0原来包含New ...
- Earmaster——音乐爱好者必备软件
有很多喜爱音乐但是却由于一些"不可抗力"而没能学习到音乐基础的小伙伴,相信你们在自学乐器或是声乐的时候总会因为基础不扎实而看不懂一些复杂的乐谱,换别的曲子练习之后发现依旧看不懂,由 ...
- synchronized关键字的可重入性
/**父类*/public class SynchronizedDemo1 implements Runnable { @Override public void run() { try { meth ...
- DIV设置滚动条在最底端
网站聊天样式,无论添加什么内容div的滚动条都显示在最底端 将div添加滚动条,给div一定的高度 <div id='up' style='height:100px; width:400px;o ...
- TCP接收窗口为什么变大了?
今天用wireshark抓取TCP连接时的报文发现客户端的Win变大了,这里是使用了Window Scale来扩张TCP接收窗口,使得接收窗口可以大于65535字节. 首先1号包是TCP第一次握手连接 ...
- mycat分片及主从(二)
一.mycat分片规则 经过上一篇幅讲解,应该很清楚分片规则配置文件rule.xml位于$MYCAT_HOME/conf目录,它定义了所有拆分表的规则.在使用过程中可以灵活使用不同的分片算法,或者对同 ...
- Java基础教程——JUnit和TDD
JUnit JUnit是一个Java的单元测试工具. package ah; public class MyCode { public int m1() { System.out.println(&q ...
- 编程C语言进阶篇——自定义数据类型:共同体
什么是"自定义数据类型"?顾名思义,就是用户可以随时在程序中自行定义新的数据类型.自定义数据类型时需要设置数据类型的名称及其成员.数据类型成员各属性的设置方法等同于变量设置时相应属 ...
- schema设计陷阱
1.太多的列: mysql的存储引擎api工作时需要在服务器层和存储引擎层之间通过行缓冲格式拷贝数据,然后在服务器层将缓冲内容解码成各个列.从行缓冲中将编码过的列转换成行数据结构的操作代价是非常高的. ...
- 必须掌握的Spark调优技术点
在利用Spark处理数据时,如果数据量不大,那么Spark的默认配置基本就能满足实际的业务场景.但是当数据量大的时候,就需要做一定的参数配置调整和优化,以保证业务的安全.稳定的运行.并且在实际优化中, ...