一.吸顶楼层

效果图:

功能思路分析:

1. 面向对象框架

2. 渲染导航

\1. 数据

\2. 对象结构的数据用for in遍历

\3. 渲染时将属性名设为锚点(a标签的href)

3. 渲染车系

\1. 车系分类是对象的数据结构,外层渲染用for in

\2. 每个分类的内容是数组的数据结构,内层渲染map().join(‘’)

\3. 渲染时将每个字母的分类设为id名,配合导航里的锚点

4. 导航吸顶

\1. 绑定滚动事件(window.addEventListener(‘scroll’,fn))

\2. 获取滚动距离( document.documentElement.scrollTop || document.body.scrollTop)

\3. 判断滚动距离是否大于导航的offsetTop

\4. 是则变成固定定位( fixed ),否则取消固定定位(static)

5. 楼层滚动

\1. 滚动事件中,拿到每一层楼的offsetTop 跟 滚动距离比较

\2. 滚动距离大于楼层的offsetTop则当前楼层对应的导航高亮

#二.星级评分

效果图:

功能思路分析:

1. 面向对象框架

2. 星级评分

\1. 为所有的小星星绑定mouseover事件:

\2. 将经过的那一个及之前的所有小星星变为红色,将之后的小星星变为灰色

\3. 为所有的小星星绑定mouseout事件:

\4. 获取当前选中的星星的下标,获取父元素的自定义属性(getAttribute())

\5. 如果有选中的小星星,则将选中星星及之前的小星星显示为红色,之后的显示为灰色

\6. 如果没有选中的小星星,则将所有的小星星变为灰色

\7. 为所有的小星星绑定click事件:

\8. 将点击的那一个及之前的所有小小变为红色,将之后的小星星变为灰色

并给父元素添加一个自定义属性(setAttribute()),存储点击的这颗小星星的下标

3. 选中标签

点击标签,选中高亮,再次点击取消选中状态**(classList.toggle())**

4. 添加标签

\1. 点击提交按钮,创建节点( document.createElement() )

\2. 设置内容为文本框的value值

\3. 追加到ul中**(添加节点appendChild() )**

5. 字数统计功能

1. 给文本框绑定input事件

\2. 获取它的value值,将value用正则将汉字替换成两个单字节字符,replace(/[\u4e00-\u9fa5]/g,‘aa’)

\3. 替换后获取字符的个数,即length

\4. 用140-length为还可以输入的字数显示到页面中

#三.今日小结

\1. 滚动事件: **window.addEventListener( ** ‘scroll’)

\2. 滚动距离: document.documentElement.scrollTop || document.body.scrollTop

\3. 鼠标事件**: mouseover滑过 mouseout离开**

\4. 中文正则: /[\u4e00-\u9fa5]/

\5. 创建节点: document.createElement()

\6. 追加节点: 父元素.appendChild()

#四.作业 -- 购物车

效果图:

功能思路分析:

1. 模拟数据

2. 渲染数据

3. 产品数量加减

通过事件委托给购物车大盒子绑定点击事件,判断事件源,实现商品数据加减,商品数量加减的同时,后面的小计跟着变化

4. 商品选中

单个商品选中后计算总计

5. 总计方法

\1. 封装一个总计方法

\2. 拿到所有被选中的商品的数量累加在一起

\3. 拿到所有被选中的商品的价格累加在一个

\6. 删除商品

点击商品后面的删除能够删除商品

js下 Day19、综合案例的更多相关文章

  1. JS 下拉菜单案例

    css代码 .nav { width: 300px; height: 400px; list-style: none; padding:; margin: 0 auto; } .nav>li { ...

  2. js下 Day12、案例

    一.垃圾分类 效果图: 功能思路分析: 1. 鼠标按下 (1) 获取鼠标到元素的距离(e.offsetX) (2) 开启开关变量 (3) 获取事件源 (4) 记录垃圾初始位置 ​  2. 鼠标移动 ( ...

  3. js下 Day11、案例

    一.成绩分类 效果图: 功能思路分析: 1. 渲染数据 2. 鼠标按下开启拖拽 \1. 给成绩盒子绑定鼠标按下事件(mousedown),用事件委托做多个标签的拖拽 \2. 开启控制拖拽的变量 \3. ...

  4. Ext.js入门:常用组件与综合案例(七)

    一:datefield简单示例 二:timefield简单示例 三:numberfield简单示例 四:FormPanel提交   datefield简单示例: <html xmlns=&quo ...

  5. js上 二十、综合案例

    二十.综合案例 题目一: **1. ** 数组随机 描述,写randomArray函数,传递一个数组,传递一个数值,返回一个指定个数的随机的新数组,不允许有重复数据 用例: randomArray([ ...

  6. js上 十九、综合案例

    十九.综合案例 题目一: 封装一个函数equal(a1,a2),传入两个一维数组,判断两个数组是否包含相同的元素,如果相等,函数的返回值为true, 不相等,函数的返回值为false 1)例:arr1 ...

  7. JavaScript:综合案例-表单验证

    综合案例:表单验证 开发要求: 要求定义一个雇员信息的增加页面,例如页面名称为"emp_add.htmnl",而后在此页面中要提供有输入表单,此表单定义要求如下: .雇员编号:必须 ...

  8. 黑马eesy_15 Vue:04.综合案例(前端Vue实现)

    黑马eesy_15 Vue:02.常用语法 黑马eesy_15 Vue:03.生命周期 黑马eesy_15 Vue:04.Vue案例(ssm环境搭建) 黑马eesy_15 Vue:04.综合案例(前端 ...

  9. JQuery:JQuery基本语法,JQuery选择器,JQuery DOM,综合案例 复选框,综合案例 随机图片

    知识点梳理 课堂讲义 1.JQuery快速入门 1.1.JQuery介绍 jQuery 是一个 JavaScript 库. 框架:Mybatis (jar包) 大工具 插件:PageHelper (j ...

随机推荐

  1. 深度分享:面试阿里,字节跳动,美团90%会被问到的HashMap知识

    一,HashTable 哈希表,它相比于hashMap结构简单点,它没有涉及红黑树,直接使用链表的方式解决哈希冲突. 我们看它的字段,和hashMap差不多,使用table存放元素 private t ...

  2. 「LOJ 6287」诗歌

    题面 LOJ 6287 Solution 枚举中间点\(j\),题目即求是否存在\(m\)使\(a[j]-m\)与\(a[j]+m\)分别在\(j\)两侧. 对于\(j\)左侧任意一个点\(i\),都 ...

  3. 实战教程:如何将自己的Python包发布到PyPI上

    1. PyPi的用途 Python中我们经常会用到第三方的包,默认情况下,用到的第三方工具包基本都是从Pypi.org里面下载. 我们举个栗子: 如果你希望用Python实现一个金融量化分析工具,目前 ...

  4. vulnhub: DC 3

    通过nmap扫描,只开放了80端口,并且该web服务是基于Joomla搭建: root@kali:~# nmap -A 192.168.74.140 Starting Nmap 7.80 ( http ...

  5. P4771 八百标兵奔北坡

    观察题目中关于北边的定义,发现是以当前点为顶点,向上的倒三角(自己想想为什么). 然后就可以直接 DP 了,令 \(f_{i,j}\) 表示点 \(\left(i,j\right)\) 的答案. \[ ...

  6. web.xml之servlet与filter配置

    servlet配置 一个完整的servlet配置分为两块,< servlet >块和< servlet-mapping >块 < servlet > <ser ...

  7. python删除list中的空list

    list1 = [[], [], [], [], [], 'text', 'text2', [], 'moreText'] 如何删除空列表,以便我得到: list2 = ['text', 'text2 ...

  8. SpringBoot第十二集:度量指标监控与异步调用(2020最新最易懂)

    SpringBoot第十二集:度量指标监控与异步调用(2020最新最易懂) Spring Boot Actuator是spring boot项目一个监控模块,提供了很多原生的端点,包含了对应用系统的自 ...

  9. 微软发布 Pylance:改善 VS Code 中的 Python 体验

    原标题:微软发布 Pylance:改善 VS Code 中的 Python 体验 来源:开源中国 微软宣布推出一种新的 Python 语言服务器,名为 Pylance,其可利用语言服务器协议与 VS ...

  10. maven依赖问题的出现原因与解决方式

    摘要 maven依赖问题作为开发者应该是经常遇到的问题,在个人单独开发单独维护的项目里,可能体现不那么明显,一是自己对导入的jar大部分都很明确,二是出现问题第一解决发现也很快,问题就没那么严重,而在 ...