Web前端开发 小实训(三) 商品秒杀小练习

学生能够在本次实训中完成商品秒杀页面的基本逻辑

任务要求

能够实现某一个商品的秒杀,在倒计时结束后不再进行秒杀。

操作步骤

1、打开预设好的页面

<html><head><meta charset="utf-8"><title>秒杀</title><link rel="stylesheet" href="css/ms.css"></head><body><div class="container"><div class="item ms"><h2 class="title">商品秒杀</h2><h3 class="subtitle">FLASH DEALS</h3><i class="icon"></i><p class="desc">本场距离结束时间</p><div class="clock"><span id="hours" class="hour">00</span><span class="point">:</span><span id="minutes" class="minute">00</span><span class="point">:</span><span id="seconds" class="second">59</span></div></div><div class="item"><a href="#" class="product-link"><img src="https://img20.360buyimg.com/seckillcms/s280x280_jfs/t28882/109/582315249/52026/e4ff99b9/5bf7cb37N98f8ac82.jpg.webp"alt="商品" height="130"><p class="product-desc">3M 节气门清洗剂【不伤镀层|多功能除油泥除积碳|8866升级】汽车金属件润滑节流阀去油污非化清剂PN18066</p><div class="price"><span class="price-new">134.00</span><span class="price-old">208.00</span><button class="button_allow">抢购 </button></div></a></div><div class="item"><a href="#" class="product-link"><img src="https:///img12.360buyimg.com/seckillcms/s280x280_jfs/t1/116581/22/13747/111761/5f2373f5E2f543b8f/8a64bb1f2303930b.jpg.webp"alt="商品" height="130"><p class="product-desc">华为nova7 SE 5G手机【12期免息可选/送碎屏险】 全网通 幻夜黑 8G+128G</p><div class="price"><span class="price-new">1324.00</span><span class="price-old">4208.00</span><button class="button_allow">抢购 </button></div></a></div><div class="item"><a href="#" class="product-link"><img src="https:///img12.360buyimg.com/seckillcms/s280x280_jfs/t1/144957/21/3917/192269/5f1fcf99E314ac8a7/75a2d6a7cabc3d72.jpg.webp"alt="商品" height="130"><p class="product-desc">雷公馆 毛呢大衣女秋冬新品毛呢外套羊毛呢宽松显瘦呢子大衣中长款单排扣品牌上衣 米白色 M</p><div class="price"><span class="price-new">324.00</span><span class="price-old">908.00</span><button class="button_allow">抢购 </button></div></a></div></div>
</body>
</html>

css

/*位置在css目录下,名字为 ms.css*/
*{margin: 0px;padding: 0px;font: 12px/1.5 Tahoma, Arial, Harrington, "微软雅黑" /*给标签一个初始大小 12像素 1.5倍行距 管理字体*/
}
a{text-decoration: none;/*去掉默认链接的下划线*/color: black;
}
a:hover{color: red;/*实现鼠标上去变色*/
}
.container{/*border: red solid 1px;*/overflow: hidden;	
}
.item{float: left;width: 190px;height: 260px;border: #877D7D solid 1px;			
}
.ms{/*秒杀模块拥有单独的背景色 且模块的字体是白色*/background-color: #D90D0D;color: white;text-align: center;/*表示里面所有的模块是居中的*/
}
.ms .title{/*秒杀模块的字体*/font-size: 30px;margin: 15px;/*距头顶*/
}
.ms .subtitle{font-size: 20px;color: rgba(255,255,255,0.5);/*含有透明色*/margin-bottom: 10px;/*和下一个模块保持距离*/
}
.ms .icon{/*那个闪电描述 这个盒子*/width: 30px;height:57px;/*此时没有显示 */display: block;/*i元素通过这个显示属性*/background-image: url(../images/3.jpg);/*此时只显示了一小部分 需要移动*/background-position: -130px -102px;margin:0 auto 15px;/*块状模块的居中*/ /*和下一个模块保持距离*/}
.ms .desc{font-size: 16px;margin: 5px;}
/*后代选择器*/
.ms .clock span.second,span.hour,span.minute{display: inline-block;/*并排显示 更是为了可以人为指定宽度*/width: 40px;height: 40px;background-color: black;font-size: 20px;line-height: 40px;/*让字体的显示在中间按*/	
}
.ms .clock span.point{display: inline-block;/*并排显示 更是为了可以人为指定宽度*/width: 10px;height: 40px;font-size: 20px;line-height: 40px;/*让字体的显示在中间按*/
}
.product-link{display: block;height: 100%;text-align: center;padding-top: 39px;
}
.product-desc{/*文字显示在一行并且没显示的用...代替*/white-space: nowrap;/*文字不换行*/width: 160px;overflow: hidden;text-overflow: ellipsis;/*超出部分使用..代替*/margin: 0 auto 20px;	}
.price{width: 160px;height: 20px;background-color: red;margin: 0 auto;padding:1px;
}
.price span{width: 78px;height: 20px;font-size: 14px;display: inline-block;
}
.price .price-new{line-height: 20px;color: antiquewhite;}
.price .price-old{color: white;background-color: #766364;}.price .button_allow{width: 160px;height: 20px;font-size: 14px;margin-top: 5px;color: white;display: inline-block;background-color: red;}.price .button_forbid{width: 160px;height: 20px;font-size: 14px;margin-top: 5px;color: white;display: inline-block;background-color:  #766364;
}

2、设置秒杀结束时间

//单独设置一个结束时间,人为定义
let endTime = new Date("2024-5-5 10:00:00").getTime();

3、声明变量保存剩余的时间

// 2、声明变量保存剩余的时间
let hours, minutes, seconds = 0;

4、 设置定时器,实现限时秒杀效果

 function ms() {alert("秒杀开始了!")//4、设置定时器let interval =  window.setInterval(function () {//实际业务}, 1000);}//调用该方法ms();

5、 获取时间差(单位秒),并判断秒杀是否过期

 let now = new Date();//获取当前时间//获取设置的时间差 remaining 差距let remaining = endTime - now.getTime();//只要时间差大于0 就可以进行倒计时 if (remaining > 0) {//简易版:转化为还差多少秒let seconds = parseInt(remaining / 1000);//还差多少秒 转化为整数秒seconds = seconds < 10 ? "0"+seconds:seconds; //小于 0 则为0+秒数document.getElementById("seconds").innerText = seconds;} else {//结束了alert("秒杀结束了!");//复位document.getElementById("seconds").innerText = "00";}

6、取消定时器

 } else {//结束了alert("秒杀结束了!");//6、在停止后结束取消定时器window.clearInterval(interval);
}

7、设置演示当前效果(将 倒计时时间设置为大于 当前时间)

8、倒计时结束前可以点击抢购获取商品(补充:onclick事件)

<button class="button_allow" onclick="alert('恭喜你抢到了清洁剂!')">抢购 </button>
<button class="button_allow" onclick="alert('恭喜你抢到了nova7SE!')">抢购 </button>
<button class="button_allow" onclick="alert('恭喜你抢到了毛呢大衣!')">抢购 </button>

9、倒计时结束后修改按钮样式,并使其不再进行点击

//结束了
alert("秒杀结束了!");
document.getElementById("seconds").innerText = "00";//6、在停止后结束取消定时器
window.clearInterval(interval);//8、让所有按钮修改弹出样式
let buttonList = document.getElementsByTagName("button");
for(let index = 0 ; index < buttonList.length; index ++){   buttonList[index].setAttribute("disabled","true");//不再进行点击buttonList[index].removeAttribute("onclick");//移除点击事件buttonList[index].classList.replace("button_allow","button_forbid");

10、查看最终效果

完整代码:

<html><head><meta charset="utf-8"><title>秒杀</title><link rel="stylesheet" href="css/ms.css"></head><body><div class="container"><div class="item ms"><h2 class="title">商品秒杀</h2><h3 class="subtitle">FLASH DEALS</h3><i class="icon"></i><p class="desc">本场距离结束时间</p><div class="clock"><span id="hours" class="hour">00</span><span class="point">:</span><span id="minutes" class="minute">00</span><span class="point">:</span><span id="seconds" class="second">59</span></div></div><div class="item"><a href="#" class="product-link"><img src="https://img20.360buyimg.com/seckillcms/s280x280_jfs/t28882/109/582315249/52026/e4ff99b9/5bf7cb37N98f8ac82.jpg.webp"alt="商品" height="130"><p class="product-desc">3M 节气门清洗剂【不伤镀层|多功能除油泥除积碳|8866升级】汽车金属件润滑节流阀去油污非化清剂PN18066</p><div class="price"><span class="price-new">134.00</span><span class="price-old">208.00</span><button class="button_allow" onclick="alert('恭喜你抢到了3M清洁剂!')">抢购 </button></div></a></div><div class="item"><a href="#" class="product-link"><img src="//img12.360buyimg.com/seckillcms/s280x280_jfs/t1/116581/22/13747/111761/5f2373f5E2f543b8f/8a64bb1f2303930b.jpg.webp"alt="商品" height="130"><p class="product-desc">华为nova7 SE 5G手机【12期免息可选/送碎屏险】 全网通 幻夜黑 8G+128G</p><div class="price"><span class="price-new">1324.00</span><span class="price-old">4208.00</span><button class="button_allow" onclick="alert('恭喜你抢到了华为nova7 SE!')">抢购 </button></div></a></div><div class="item"><a href="#" class="product-link"><img src="//img12.360buyimg.com/seckillcms/s280x280_jfs/t1/144957/21/3917/192269/5f1fcf99E314ac8a7/75a2d6a7cabc3d72.jpg.webp"alt="商品" height="130"><p class="product-desc">雷公馆 毛呢大衣女秋冬新品毛呢外套羊毛呢宽松显瘦呢子大衣中长款单排扣品牌上衣 米白色 M</p><div class="price"><span class="price-new">324.00</span><span class="price-old">908.00</span><button class="button_allow" onclick="alert('恭喜你抢到了毛呢大衣!')">抢购 </button></div></a></div></div><script>//  1、设置秒杀结束时间 转化为 time类型let endTime = new Date("2024-5-5 10:46:20").getTime(); //将时间转化为 毫秒,用于后续计算// 2、声明变量保存剩余的时间let hours, minutes, seconds = 0;//3、设置方法 用于计算是否到时间了function ms() {alert("秒杀开始了!")//4、设置定时器let interval =  window.setInterval(function () {let now = new Date();//获取当前时间//获取设置的时间差 remaining 差距let remaining = endTime - now.getTime();//只要时间差大于0 就可以进行倒计时 if (remaining > 0) {//简易版:转化为还差多少秒let seconds = parseInt(remaining / 1000);//还差多少秒 转化为整数秒seconds = seconds < 10 ? "0"+seconds:seconds; //小于 0 则为0+秒数document.getElementById("seconds").innerText = seconds;} else {//结束了alert("秒杀结束了!");document.getElementById("seconds").innerText = "00";//6、在停止后结束取消定时器window.clearInterval(interval);//让所有按钮修改弹出样式let buttonList = document.getElementsByTagName("button");for(let index = 0 ; index < buttonList.length; index ++){   buttonList[index].setAttribute("disabled","true");//不再进行点击buttonList[index].removeAttribute("onclick");//移除点击事件buttonList[index].classList.replace("button_allow","button_forbid");}}}, 1000);}//调用该方法ms();</script>
</body></html>

11、思考,如何实现小时,分钟,秒数的显示?

//参考代码
<!doctype html>
<html><head><meta charset="utf-8"><title>秒杀</title><link rel="stylesheet" href="css/ms.css"></head><body><div class="container"><div class="item ms"><h2 class="title">商品秒杀</h2><h3 class="subtitle">FLASH DEALS</h3><i class="icon"></i><p class="desc">本场距离结束时间</p><div class="clock"><span id="hours" class="hour">00</span><span class="point">:</span><span id="minutes" class="minute">00</span><span class="point">:</span><span id="seconds" class="second">59</span></div></div><div class="item"><a href="#" class="product-link"><img src="https://img20.360buyimg.com/seckillcms/s280x280_jfs/t28882/109/582315249/52026/e4ff99b9/5bf7cb37N98f8ac82.jpg.webp"alt="商品" height="130"><p class="product-desc">3M 节气门清洗剂【不伤镀层|多功能除油泥除积碳|8866升级】汽车金属件润滑节流阀去油污非化清剂PN18066</p><div class="price"><span class="price-new">134.00</span><span class="price-old">208.00</span><button class="button_allow" onclick="alert('恭喜你抢到了3M清洁剂!')">抢购 </button></div></a></div><div class="item"><a href="#" class="product-link"><img src="//img12.360buyimg.com/seckillcms/s280x280_jfs/t1/116581/22/13747/111761/5f2373f5E2f543b8f/8a64bb1f2303930b.jpg.webp"alt="商品" height="130"><p class="product-desc">华为nova7 SE 5G手机【12期免息可选/送碎屏险】 全网通 幻夜黑 8G+128G</p><div class="price"><span class="price-new">1324.00</span><span class="price-old">4208.00</span><button class="button_allow" onclick="alert('恭喜你抢到了华为nova7 SE!')">抢购 </button></div></a></div><div class="item"><a href="#" class="product-link"><img src="//img12.360buyimg.com/seckillcms/s280x280_jfs/t1/144957/21/3917/192269/5f1fcf99E314ac8a7/75a2d6a7cabc3d72.jpg.webp"alt="商品" height="130"><p class="product-desc">雷公馆 毛呢大衣女秋冬新品毛呢外套羊毛呢宽松显瘦呢子大衣中长款单排扣品牌上衣 米白色 M</p><div class="price"><span class="price-new">324.00</span><span class="price-old">908.00</span><button class="button_allow" onclick="alert('恭喜你抢到了毛呢大衣!')">抢购 </button></div></a></div></div><script>//  1、设置秒杀结束时间 转化为 time类型let endTime = new Date("2024-5-11 11:26:20").getTime(); //将时间转化为 毫秒,用于后续计算// 2、声明变量保存剩余的时间let hours, minutes, seconds = 0;//3、设置方法 用于计算是否到时间了function ms() {alert("秒杀开始了!")//4、设置定时器let interval =  window.setInterval(function () {let now = new Date();//获取当前时间//获取设置的时间差 remaining 差距let remaining = endTime - now.getTime();//只要时间差大于0 就可以进行倒计时 if (remaining > 0) {//简易版:转化为还差多少秒hours = parseInt((remaining /1000/3600));  // 计算剩余小时(除以60*60转换为小时,获取剩余的小时)minutes = parseInt((remaining /1000 / 60) % 60);    // 计算剩余分钟(除以60转为分钟,与60取模,获取剩余的分钟)seconds = parseInt(remaining /1000 % 60 ); //计算60秒内还有几秒hours = hours < 10 ? '0' + hours : hours;minutes = minutes < 10 ? '0' + minutes : minutes;seconds = seconds < 10 ? '0' + seconds : seconds;console.log(hours + ","+minutes+","+seconds)document.getElementById("hours").innerText = hours;document.getElementById("minutes").innerText = minutes;document.getElementById("seconds").innerText = seconds;} else {//结束了alert("秒杀结束了!");document.getElementById("hours").innerText = "00";document.getElementById("minutes").innerText = "00";document.getElementById("seconds").innerText = "00";//6、在停止后结束取消定时器window.clearInterval(interval);//让所有按钮修改弹出样式let buttonList = document.getElementsByTagName("button");for(let index = 0 ; index < buttonList.length; index ++){   buttonList[index].setAttribute("disabled","true");//不再进行点击buttonList[index].removeAttribute("onclick");//移除点击事件buttonList[index].classList.replace("button_allow","button_forbid");}}}, 1000);}//调用该方法ms();</script>
</body></html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3031237.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

若依生成树表和下拉框选择树表结构(在其他页面使用该下拉框输入)

1.数据库表设计 生成树结构的主要列是id列和parent_id列&#xff0c;后者指向他的父级 2.来到前端代码生成器页面 导入你刚刚写出该格式的数据库表 3.点击编辑&#xff0c;来到字段 祖籍列表是为了好找到直接父类&#xff0c;不属于代码生成器方法&#xff0c;需要后台编…

[js] 递归,数组对象根据某个值进行升序或者降序

一、效果图 1.1 父级 1.2 父级与子级 二、代码 升序降序&#xff0c;只要把 a.num - b.num 改成 b.num - a.num <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, i…

Apache Flume概述

Apache Flume概述 1.Flume定义 ​ Flume是cloudera(CDH版本的hadoop) 开发的一个分布式、可靠、高可用的海量日志收集系统。 它将各个服务器中的数据收集起来并送到指定的地方去&#xff0c;比如说送到HDFS、Hbase&#xff0c;简单来说flume就是收集日志的。 2.Flume基础架构…

读天才与算法:人脑与AI的数学思维笔记24_预测性文本生成器

1. 起源 1.1. 人类讲故事可能起源于“假如……”这种问答结构 1.2. 讲故事是人类做安全试验的一种方式 1.2.1. 如果你问一个人“假如……”&#xff0c;其实是在探索你的行为对他可能带来的影响 1.3. 最早出现的故事极有可能就源自我们对在周遭混乱的环境中寻找某种秩序的渴…

西门子PLC定时器使用与疑难杂症

一、简介 S7-200提供了256个定时器&#xff0c;依据分辨率分三种类型&#xff1a;1ms&#xff0c;10ms和100ms&#xff1b;依据功能分为接通延时定时器&#xff08;TON&#xff09;、有记忆的接通延时定时器&#xff08;TONR)和断开延时定时器&#xff08;TOF)。 接通延时定时…

【架构】MVC架构模式 三层架构

1 不使用MVC架构模式完成银行账户转账 <% page contentType"text/html;charsetUTF-8" language"java" %> <html><head><base href"${pageContext.request.scheme}://${pageContext.request.serverName}:${pageContext.request.…

多个.C文件被编译为一个可执行文件的详细过程

多个.C文件被编译为一个可执行文件的详细过程 文章目录 多个.C文件被编译为一个可执行文件的详细过程前言一、一个.C文件的编译过程二、多个.C文件的链接过程1.文件信息2.链接过程3.makefile 总结 前言 C语言经典的 “hello world ” 程序从编写、编译到运行&#xff0c;看到屏…

大型外企都在用的邮件大附件系统,究竟哪里好?

外企的业务往来复杂&#xff0c;内部沟通频繁&#xff0c;且普遍采用邮件作为沟通方式&#xff0c;外企一般使用的邮件系统多种多样&#xff0c;但其中一些较为常见和广泛使用的包括Zoho Mail和Outlook等。 Outlook作为微软旗下的全球主流电子邮件服务提供商之一&#xff0c;也…

GAME101-Lecture06学习

前言 上节课主要讲的是三角形的光栅化。重要的思想是要利用像素的中心对三角形可见性的函数进行采样。 这节课主要就是反走样。 课程链接&#xff1a;Lecture 06 Rasterization 2 (Antialiasing and Z-Buffering)_哔哩哔哩_bilibili 反走样引入 ​ 通过采样&#xff0c;得到…

Spring Boot集成activiti快速入门Demo

1.什么事activiti&#xff1f; Activiti是一个工作流引擎,可以将业务系统中复杂的业务流程抽取出来,使用专门的建模语言BPMN2.0进行定义,业务流程按照预先定义的流程进行执行,实现了系统的流程流activiti进行管理,减少业务系统由于流程变更进行系统升级改造的工作量,从而提高系…

2024全新小狐狸AI免授权源码

源码安装说明&#xff1a; 下 载 地 址 &#xff1a; runruncode.com/php/19757.html 1. 在宝塔新建一个站点&#xff0c;选择 PHP 版本为 7.2、7.3 或 7.4。将压缩包上传到站点的根目录&#xff0c;并设置运行目录为 /public。 2. 导入数据库文件&#xff0c;该文件位于 …

如何通过汽车制造供应商协同平台,提高供应链的效率与稳定性?

汽车制造供应商协同是指在汽车制造过程中&#xff0c;整车制造商与其零部件供应商之间建立的一种紧密合作的关系。这种协同关系旨在优化整个供应链的效率&#xff0c;降低成本&#xff0c;提高产品质量&#xff0c;加快创新速度&#xff0c;并最终提升整个汽车产业的竞争力。以…

Vue3专栏项目 -- 三、使用vue-router 和 vuex(上)

前面我们开发了两个页面的组件&#xff0c;现在我们需要把它们分成几个页面了&#xff0c;那么一个网页多个页面我们都熟悉&#xff0c;针对不同的url渲染不同的html静态页面&#xff0c;这是web世界的基本工作方式。 有时候我们点击一个东西&#xff0c;地址栏的路由跳转&…

二级等保与三级等保的区别有哪些

二级等保和三级等保的区别主要体现在保护能力、安全要求、监管严格程度等方面。以下是根据提供的搜索结果中关于二级和三级等保的具体差异&#xff1a; 1. 保护能力&#xff1a; 二级等保要求信息系统能够防护来自外部小型组织的威胁&#xff0c;发现重要的安全漏洞和事件&…

机器学习实战宝典:用scikit-learn打造智能应用

书接上文——《数据探险家的终极指南&#xff1a;用Python挖掘机器学习的奥秘》 前文我们在这段精彩的机器学习探险之旅中&#xff0c;从基础概念出发&#xff0c;深入探索了使用Python和scikit-learn库进行数据分析和模型构建的全过程。 我们首先了解了机器学习的基本原理&am…

Nextcloud私有云盘-重新定义云存储体验

Nextcloud私有云盘-重新定义云存储体验 1. 什么是Nextcloud ​ Nextcloud是一个开源的云存储和协作平台&#xff0c;旨在为个人用户、企业和团队提供安全、隐私保护的数据存储和共享解决方案。它允许您在不同设备之间同步、共享文件&#xff0c;提供了强大的协作工具和应用生…

上网卡免费领取,无成本,免费领,超暴力蓝海项目

随着短视频和直播的流行&#xff0c;对大流量电话卡的需求日益增加。我们提供100G-300G大流量电话卡&#xff0c;包含100多分钟语音通话&#xff0c;月费仅19-29元。这些都是三大运营商的靠谱已有号卡&#xff0c;全国免费领取并包邮到家。客户收到卡片后&#xff0c;可在线充值…

工作中使用IDEA查看Stream变化

工作中使用IDEA查看stream变化 代码debug调试 代码 package com.demo;import java.util.stream.LongStream;public class LamdaDemo {public static void main(String[] args) {long[] dataResult LongStream.of(1,5,7,9).filter(data -> data > 10).map(data -> da…

C++学习第二十九课:C++ 输入输出流详解:从基础到高级应用

在 C 中&#xff0c;流&#xff08;stream&#xff09;是一种用于实现输入输出操作的抽象概念。流可以看作是字节的流动&#xff0c;这些字节可以从一个地方流向另一个地方&#xff0c;例如从键盘输入到程序中&#xff0c;或者从程序输出到屏幕。C 提供了一套完整的流库来处理各…

C语言什么是散列法?

一、问题 什么是散列法&#xff1f; 二、解答 散列法是⼀种将字符组成字符串&#xff0c;转换为固定长度&#xff08;⼀般是更短长度&#xff09;的数值或索引值的⽅法&#xff0c;也叫哈希法&#xff0c;⼜可以称为杂凑法或关键码⼀地址转换法。 那么&#xff0c;通过散列函数…