一.摇一摇

效果图:

img

功能思路分析:

1. 功能一:页面切换

(1) 点击第一页的设置按钮,从第一页切换到第二页

(2) 点击第二页的返回按钮,从第二页切换到第一页

(3) 第二页的标题发生改变后,第一页的标题也跟着改变

2. 功能二:抽奖

(1) 点击”摇”时,从第二个页面拿到所有的内容进行随机抽奖,用**(setInterval())**显示抽奖过程

(2) 用**(setTimeout())**3秒后结束抽奖

3. 功能三:添加内容

(1) 点击加号按钮添加内容

(2) 1.创建节点( document.createElement() ) => 2.设置内容( innerHTML ) => 3.将创建的节点放在加号前面( 父元素.insertBefore() )

4. 功能四:删除内容

(1) 利用事件委托做删除功能,给大盒子绑定点击事件

(2) 判断**事件源(e.target.className)**是否为删除按钮,是的话则完成删除功能

#二.滚动弹幕

效果图:

img

功能思路分析:

1. 淡出隐藏

让第一个li的透明度**(opacity)为0**,过渡**(transition)时间500毫秒**

2. 向上滚动

(1) 当第一个动画效果完成后开始执行第二个动画效果,**(500 ** 毫秒之后执行setTimeout())。

(2) 让ul整体向上移动一个li的高度( marginTop ),过渡**(transition)时间500毫秒**

3. 无缝衔接

(1) 当以上两个动画效果完成后( 两次动画效果共用时1秒,1秒之后执行 )继续重复执行下一次滚动

(2) 将隐藏的li追加到ul的末尾(appendChild()),并显示( opacity = 1 )

(3) ul恢复初始位置,但需要清除过渡效果( 偷天换日,避免有向下滚动的bug )

(4) 无缝滚动重复执行,封装成函数反复调用

#三.今日小结

1.事件委托: 给大盒子绑定事件,判断事件源 e.target

2.类名添加删除: classList.add() classList.remove()

3.节点创建: document.createElement()

4.插入节点: 父元素.appendChild() 父元素.insertBefore()

5.定时器: setInterval() setTimeout()

#四.作业 -- 轮播留言板

效果图:

img

功能思路分析:

\1. 背景轮播

给body标签添加背景图,通过修改背景图的路径实现自动轮播

2. 显示弹框遮罩

点击添加按钮,显示遮罩和弹框,通过修改遮罩的display样式实现

\3. 隐藏弹框遮罩

点击弹框中取消按钮和XX按钮,隐藏遮罩

\4. 添加留言

(1) 点击弹框中提交按钮,发表留言

(2) 1.创建节点( document.createElement()) => 2.设置内容( innerHTML ) => 3.放入指定盒子( appendChild() )

\5. 删除留言

(1) 给留言区大盒子绑定点击事件,利用事件委托实现删除

(2) 判断**事件源(e.target.className)**是否为删除按钮,是则删除留言

js下 Day08、DOM案例的更多相关文章

  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. JS对象与Dom对象与jQuery对象之间的区别

    前言 通过问题看本质: 举例: js的写法:document.getElementById('save').disabled=true; 在jquery中我是这样写的 $("#save&qu ...

  5. js中的DOM操作汇总

    一.DOM创建 DOM节点(Node)通常对应于一个标签,一个文本,或者一个HTML属性.DOM节点有一个nodeType属性用来表示当前元素的类型,它是一个整数: Element,元素 Attrib ...

  6. js 字符串转dom 和dom 转字符串

    js 字符串转dom 和dom 转字符串 博客分类: JavaScript   前言: 在javascript里面动态创建标准dom对象一般使用: var obj = document.createE ...

  7. NPM酷库:jsdom,纯JS实现的DOM

    NPM酷库,每天两分钟,了解一个流行NPM库. 昨天认识了一个在Node.js环境下操作HTML的库 cheerio,cheerio实现了jQuery接口,用起来十分方便.为什么不直接用jQuery呢 ...

  8. z-tree官方提供的下拉菜单案例

    1.z-tree官方提供的下拉菜单案例 <!DOCTYPE html> <HTML> <HEAD> <TITLE> ZTREE DEMO - selec ...

  9. 前端(十六)—— JavaScript盒子模型、JS动画、DOM、BOM

    JS盒子模型.JS动画.DOM.BOM 一.JS盒模型 1.width | height parseInt(getComputedStyle(ele, null).getPropertyValue(' ...

随机推荐

  1. Pinpoint 更改agentid 和 agent name 长度限制(Pinpoint系列二)

    本文基于 Pinpoint 2.1.0 版本 本文的内容为了更改 ID 和 Name 长度限制,因为有使用容器或者是服务名称确实比较长,所以根据业务场景,我们需要更改源码来实现这个. 具体更改,参考 ...

  2. SwiftUI:看我展示52张扑克牌,“很快啊!”

    目录 思路 效果图 相关代码解析 枚举创建扑克牌号码 枚举创建扑克牌类型 viewModel逻辑 UI实现 源码 感受 思路 使用 SwiftUI 创建 UI 结构: 使用 swift 的枚举和结构体 ...

  3. yii2.0 模态框简单使用

    1 <?php foreach($data as $model) :?> 2 3 <!-- 按钮触发模态框 --> 4 <button class="btn b ...

  4. Arduion学习(一)点亮三色发光二极管

    这是我接触Arduion以来第一个小实验 实验准备: 1.查阅相关资料,了解本次实验所用到的引脚.接口的相关知识. 2.准备Arduion板(本次实验所用到的型号为mega2560).三色发光二极管. ...

  5. Arduion学习(三)驱动温度传感器

    一.实验目的: 1.将温度值打印显示在串口监视器 1.将温度值打印显示在串口,不同温度段显示不同的灯光,并在温度过高或过低时利用蜂鸣器报警. 二.实验准备: 1.查阅相关资料,了解本次实验所用到的引脚 ...

  6. LaTeX中的插图

    插图代码及注释: 显示效果: 更多命令可以看相关文档,通过在命令行终端输入 texdoc graphicx 命令打开文档.

  7. CentOS升级参考

    CentOS生产系统升级策略: 1)升级前评估 a)确认kernel或包bug. b)用评估工具 c) 测试验证 2)确认升级内容 a)单独升级kernel b)单独升级包 c)都升级 4)确认升级方 ...

  8. Centos7配置阿里epel源|yum源

    这一步非常重要.重要.重要.在这解释一下源的概念,打个比方如果手机想获取一个软件,可以选择很多途径,如华为的华为商店,小米的应用商店,苹果的App store,源就相当于各种手机获取软件的商店.因为国 ...

  9. Spring Cloud 学习 (七) Spring Cloud Sleuth

    微服务架构是一个分布式架构,微服务系统按业务划分服务单元,一个微服务系统往往有很多个服务单元.由于服务单元数量众多,业务的复杂性较高,如果出现了错误和异常,很难去定位.主要体现在一个请求可能需要调用很 ...

  10. NOIP2020退役记

    Day 0 这一次因为疫情仍然没有试机,但是允许提前打开虚拟机,减少了调试虚拟机的时间 开考时,吸取上一次 \(CSP\) 的教训,先把题面看了一遍 感觉 \(T1\) 比较可做,剩下的暂时没有思路 ...