抛出随机数实现一个“谁取餐的小游戏”,供大家参考,具体内容如下
1、HTML结构代码如下
<div class="mask"> <div class="contents"> <div class="head"> <p>谁去拿外卖</p> <a href="#" id="close">X</a> </div> <div class="cont-wapper"> <div class="cont-inner"> <h2></h2> <button></button> <div class="sign">随机到最小数字的人去拿外卖</div> <ul> <li class="takeout-list">扔出了一个2</li> <li>扔出了一个3</li> </ul> </div> </div> </div> </div>
2、css样式代码如下
.mask { position: fixed;left: 0;top: 0; width: 100%;height: 100%; background: rgba(0, 0, 0, 0.5); } .contents { position: absolute;top: 54px;left: 50%; width: 360px;border: 1px solid gray;background: white; border-radius: 5px;transform: translateX(-50%); } .head { box-sizing: border-box;width: 100%;height: 44px; padding: 10px;border-bottom: 1px solid #eee; } .head p { float: left; } .head a { float: right;width: 16px; line-height: 24px;color: #ccc; } .head a:hover { color: blue; } .cont-wapper { width: 300px;color: #555; padding: 15px 30px;margin: 0 auto; } .cont-inner { font-size: 12px;background: #dbf0fa; padding-top: 15px;margin: 0 auto; margin-bottom: 10px;box-shadow: 1px 1px 2px #ddd; } .cont-inner h2 { width: 186px;height: 188px;margin: 0 auto; background: url('../../Content/img1/ico.png') 0 -120px no-repeat; } .cont-inner button { display: block;cursor: pointer;/*箭头变手*/ outline:none;/*去掉浏览器默认的外边框*/ width: 271px;height: 40px;border: 0; background: url('../../Content/img1/ico.png') 0 0 no-repeat; margin: -45px auto 15px; } .sign { position: relative;text-align: center; color: #777;margin-bottom: 10px; } /*after伪元素在元素之后添加内容*/ /*content 属性与 :before 及 :after 伪元素配合使用,来插入生成内容*/ .sign::after { content: '';display: block; position: absolute;width: 40px;height: 7px; background: #ccc;right: 16px;top: 5px; } /*before伪元素在元素之前添加内容。*/ /*content 属性与 :before 及 :after 伪元素配合使用,来插入生成内容*/ .sign::before { content: '';display: block;position: absolute; width: 40px;height: 7px; background: #ccc;left: 16px;top: 5px; } .cont-inner ul { height: 180px;margin: 0 10px; padding: 5px 5px 0 5px; overflow: hidden;/*隐藏滚动条*/ } .cont-wapper li.takeout-list { color: #fe5a23;font-weight: 600; height: 19px;line-height: 19px; background: url('../../Content/img1/ico.png') 0 -320px no-repeat; } .cont-wapper li { padding-left: 5px; }
3、js代码获取元素
var button = document.getElementsByTagName('button')[0];//按钮 var ullist = document.getElementsByTagName('ul')[0]; var arrList = [];//创建数组 var mask = document.getElementsByClassName('mask')[0]; var text = document.getElementsByClassName('contents')[0]; var min = NaN;//最小值 var index;//索引值
4、js代码实现鼠标滑过的时候背景的动态变化
//鼠标按下事件 button.onmousedown = function () { this.style.backgroundPosition = '0 ' + (-80) + 'px'; cteatNumer()//调用生成数组的方法 //鼠标放开事件 this.onmouseup = function () { this.style.backgroundPosition = '0 ' + (-40) + 'px'; } }; //鼠标移入事件 button.onmouseenter = function () { this.style.backgroundPosition = '0 ' + (-40) + 'px'; //鼠标移出事件 this.onmouseleave = function () { this.style.backgroundPosition = '0 ' + 0 + 'px'; } };
5、js代码实现在数组输出最小值
//在数组中输出最小值 Array.prototype.min = function () { var min = this[0];//目前生成的数值 var len = this.length;//数组目前的长度 for (var i = 1; i < len; i++) { if (this[i] < min) { min = this[i]; } } return min; }
6、js代码实现取出数组的最小值
//数组取最小值 function cteatNumer() { var num = Math.floor(Math.random() * 100);//0-100之间随机生成一个精准的实数 if (min == num) {//判断是否有最小值重复 cteatNumer();//有重复就重新生成 return; } arrList.push(num);//在数组最下面显示生成的值 if (arrList.length > 11) {//数组长度超出11 if (num > min && index == 0) {//当最小值索引值为0时 arrList.splice(1, 1);//从数组索引值为1开始,删除第2个数值 } else { arrList.shift();//数组往上移动 } } min = arrList.min();//最小值 index = arrList.indexOf(min);//最小值在数组中的索引 refurbishDom(arrList, index);//调用refurbishDom方法 }
7、用for循环遍历当前数组的长度
function refurbishDom(arr, index) { ullist.innerHTML = '';//清空ul所有的数值 var len = arr.length;//获取当前数组的长度 for (var i = 0; i < len; i++) {//显示对应索引的数值 ullist.innerHTML += '<li>' + '扔出了一个' + arr[i] + '</li>'; } //在ul数组中动态指定最小值 ullist.getElementsByTagName('li')[index].className = 'takeout-list'; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“js实现随机数小游戏”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2025年01月11日
2025年01月11日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]