js下 Day12、案例
一.垃圾分类
效果图:
功能思路分析:
1. 鼠标按下
(1) 获取鼠标到元素的距离(e.offsetX)
(2) 开启开关变量
(3) 获取事件源
(4) 记录垃圾初始位置
2. 鼠标移动
(1) 当开关变量为真时,修改垃圾的位置即的left和top
(2) 垃圾位置 = 鼠标位置到页面位置 - 鼠标到盒子的位置
3. 鼠标抬起
(1) 关闭开关变量
(2) 循环每一个垃圾桶,通过 getBoundingClientRect()方法获取垃圾桶的四个边界,判断鼠标是否进入垃圾桶
(3) 如果进入垃圾桶,再利用indexOf()检测垃圾和垃圾桶的title值
(4) 为真则删除垃圾,为假则回到原地( 鼠标按下时记录的初始位置 )
#二.仿苹果菜单
效果图:
功能思路分析:
1. 封装获取两点之间距离方法
(1) 利用勾股定理求斜边: 直角边的平方和 = 斜边的平方
(2) 求平方用Math.pow( a,2) , 开根号用Math.sqrt(c)
2. 封装获取元素中心点方法
(1) 通过getBoundingClientRect()方法拿到元素的位置尺寸信息
(2) 中心点:即 元素的left + 元素的width/2
3. 图标放大
(1) 循环每一个图标,调用imgCenter()方法拿到每一个图标的中心点
(2) 调用getPos()方法获取鼠标到图片中心点的距离
(3) 设置一个临界点,当两点之间的距离小于临界点时,图片开始放大
(4) 图标放大即修改图标的宽度,在初始宽度的基础上放大
#三.今日小结
1.获取元素的尺寸和位置信息:元素. getBoundingClientRect()
2.勾股定理: 直角边的平方 = 斜边的平方
3.开方Math.pow(值,次方)
4.开根号Math.sqrt(值)
#四.作业--选项卡三级联动
效果图:
功能要求:
1. 渲染省份
(1) 对象的数据用for in,渲染时在标签中设置自定义属性保存编码
2. 渲染城市
(1) 点击省份渲染城市,拿到标签上的编码,通过**【】方式取数据**
(2) 对象的数据用for in,渲染时在标签中设置自定义属性保存编码
3. 渲染区县
(1) 点击城市渲染城市,拿到标签上的编码,通过**【】方式取数据**
4. 选项卡切换
(1) 点击菜单,切换菜单类名和对应省市区的类名进行显示隐藏
js下 Day12、案例的更多相关文章
- 原生JS下拉加载插件分享。
无聊写了一个JS下拉加载插件,有需要的可以下载. // 使用 // new ManDownLoad("#ul","json/load.json",functio ...
- js下拉框
Js下拉框 http://sc.chinaz.com/tag_jiaoben/XiaLaKuang.html
- chart.js图表库案例赏析,饼图添加文字
chart.js图表库案例赏析,饼图添加文字 Chart.js 是一个令人印象深刻的 JavaScript 图表库,建立在 HTML5 Canvas 基础上.目前,它支持6种图表类型(折线图,条形图, ...
- CSS+JS下拉菜单和纯CSS下拉菜单
下拉菜单 (思路:先把二级定位到屏幕外,鼠标悬停重新定位回来:另一个就是ul浮动,li也浮动) 下拉菜单的一般思路就是把子导航嵌套在无序列表中,把列表定位到屏幕之外,当鼠标悬停在其父列表项上时,重新定 ...
- 小议 js 下字符串比较大小
原文:小议 js 下字符串比较大小 之前群里有人问如何比较两个时间大小,他的时间格式是 2014-08-08 而不是 2014-8-8.所以我给的方法是 直接比较,如: var a = "2 ...
- node.js 下依赖Express 实现post 4种方式提交参数
上面这个图好有意思啊,哈哈, v8威武啊.... 在2014年的最后一天和大家分享关于node.js 如何提交4种格式的post数据. 上上一篇说到了关于http协议里定义的4种常见数据的post方法 ...
- npm 是node.js下带的一个包管理工具
npm 是node.js下带的一个包管理工具 npm install -g webpack webpack是一个打包工具 gulp是一个基于流的构建工具,相对其他构件工具来说,更简洁 ...
- js调用ajax案例
js调用ajax案例 测试地址:http://www.w3school.com.cn/tiy/t.asp?f=ajax_get 嵌入下面代码,点击提交,再点击请求数据.就可以看到结果了. <ht ...
- cookie.js插件的案例
cookie.js插件的案例: https://github.com/jaywcjlove/cookie.js/blob/master/README.md 文档 api 在这里即可查看用法 ...
随机推荐
- PowerPoint无法正常加载MathType的解决方法
MathType是一款十分便捷的数学公式编辑器,可以和很多办公软件和网站兼容使用,我们日常用的比较多的也就是Office和WPS,更具体的说是Word\Excel\PPT等等一系列办公常用软件. 不过 ...
- 惠州发布5G任务计划表,将出台智慧灯杆建设计划与技术规范
广东省惠州市于近日发布<惠州市贯彻落实广东省加快5G产业发展行动计划(2019-2022年)工作任务计划表>(以下简称:<5G任务计划表>). <5G任务计划表>明 ...
- 遇见BUG如何区分前后端
定位前后端bug: 1.经验法: 软件测试人员应不断精进自己的技能,负责的项目多了,自然对功能的实现过程有了解,也就明白如何分类bug了. 例如: 网页上的某个图片的分辨率不对,如果我们了解实现过程, ...
- layer 父弹窗获取子弹窗内的dom节点元素和变量
1 var body = layer.getChildFrame('body', index); //获取子弹窗的dom节点 2 3 var iframeWin = window[layero.fin ...
- Python【内置函数】、【装饰器】与【haproxyf配置文件的修改】
内置函数 •callable,检查是否能被执行/调用 def f1(): pass f2 = 123 print(callable(f1)) #输出 print(callable(f2)) #输出 T ...
- day3(Vue组件)
1.组件定义 1.定义组件并引用 2.父组件向子组件传值 3.子组件向父组件传值 # 组件间传值:vuex (https://www.cnblogs.com/xiaonq/p/9697921.html ...
- C++ 虚基类的定义、功能、规定
原文声明:http://blog.sina.com.cn/s/blog_93b45b0f01011pkz.html 虚继承和虚基类的定义是非常的简单的,同时也是非常容易判断一个继承是否是虚继承的,虽然 ...
- 第12.6节 Python标准库其他内置模块导览
一. 文本处理服务 string模块 : 常见的字符串操作 difflib模块: 计算差异的辅助工具 textwrap模块: 文本自动换行与填充,能够格式化文本段落,以适应给定的屏幕宽度: unico ...
- HTML引入外部字体
HTML5如何引入外部字体 背景 现在我需要 "Montserrat-ExtraLight ExtraLight"类型的字体,但是html的font-family中找不到这个类型的 ...
- jQuery插件的2种类型
1.封装方法插件 封装方法插件在本质上来说,是一个对象级别的插件,这类插件首先通过jQuery选择器获取对象,并为对象添加方法,然后,将方法进行打包,封闭成一个插件,这种类型的插件编写简单,极易调用 ...