怎么新建MySQL数据库

发布时间:2022-10-21 作者:admin
阅读:297
在日常操作或是项目的实际应用中,有不少朋友对于“如何用JS写一个简单的点击数字游戏?”的问题会存在疑惑,下面小编给大家整理和分享了相关知识和资料,易于大家学习和理解,有需要的朋友可以借鉴参考,下面我们一起来了解一下吧。

 


实现一个点击数字的小游戏:依次点击容器中随机生成的数字元素,生成的数字元素会在5S后消失,你将凭借记忆点击按照数字升序依次点击生成的数字方可通过该关卡游戏。

话不多说直接看运行效果图:

上代码:

?
<!DOCTYPE html> < html lang = "en" >    < head >      < meta charset = "UTF-8" />      < meta http-equiv = "X-UA-Compatible" content = "IE=edge" />      < meta name = "viewport" content = "width=device-width, initial-scale=1.0" />      < title >点击数字小游戏</ title >      < style >        #cointainer {          margin: auto;          height: 600px;          width: 400px;          background-color: rgb(37, 37, 37);          position: relative;        }        .header {          width: auto;          text-align: center;          margin: auto;        }        .parm {          height: 60px;          width: 60px;          border-radius: 30px;          position: absolute;          text-align: center;          line-height: 60px;        }        .parm:hover {          cursor: pointer;        }        .todo {          text-align: center;          margin-top: 16px;        }        button {          width: 100px;          height: 30px;          background-color: coral;          border: none;          outline: none;        }      </ style >    </ head >    < body >      < div class = "header" >        < h1 >点击数字小游戏</ h1 >        < p >          5s后数字内容会消失,凭借你的记忆按照数字升序依次点击数字点可顺利通关        </ p >      </ div >      < div id = "cointainer" ></ div >      < div class = "todo" >        < button onclick = "restart(6)" >重新开始</ button >        < button style = "margin-left: 20px" onclick = "nextPass()" >下一关</ button >        < button          style = "margin-left: 20px"          onclick = "window.clearInterval(timmer2);window.clearTimeout(timmer1)"        >          停止计时        </ button >        < p >时间</ p >      </ div >    </ body >    < script >      let circleList = [];      //circle构造器      function getPosition() {        let parm = { x: "", y: "" };        parm.x = Math.round(Math.random() * 340);        parm.y = Math.round(Math.random() * 540);        return parm;      }      //创建不重叠circle      function createCircle(total) {        if (circleList.length === 0) {          circleList.push(getPosition());        }        //限制创建次数200        for (let i = 0; i < 200 ; i++) {          if (circleList.length < total) {            let circle = getPosition ();            let distan = [];            for (let n = 0 ; n < circleList.length; n++) {              let dis =                Math .abs(circle.x - circleList[n].x) ** 2 +                Math.abs(circle.y - circleList[n].y) ** 2;              distan.push(dis);            }            if (Math.min(...distan) > 3600) {              circleList.push(circle);            }          } else {            break;          }        }      }      //创建8个circle      createCircle(8);      //随机颜色选择器      function selectColor() {        let r = 100 + Math.round(Math.random() * 155);        let g = 100 + Math.round(Math.random() * 155);        let b = 100 + Math.round(Math.random() * 155);        return `rgb(${r},${g},${b})`;      }      //在DOM中创建circle      let containner = document.getElementById("cointainer");      //构造关卡      function creatGame(num) {        circleList = [];        createCircle(num);        for (let i = 0; i < circleList.length ; i++) {          let node = document .createElement("span");          containner.appendChild(node);          node.className = "parm" ;          node.innerText = i + 1;          node.style.left = circleList [i].x + "px";          node.style.top = circleList [i].y + "px";          node.style.backgroundColor = selectColor ();        }      }      //点击答案      let asw = [];      //设置5s后开始游戏      let start = function () {        let list = document .querySelectorAll("span");        let right = "" ;        for (let i = 0 ; i < list.length; i++) {          list[i] .innerText = "" ;          list[i] .number = i + 1;          right = right + (i + 1);          list[i].addEventListener(            "click",            function () {              asw.push(list[i].number);              if (asw.length === pass && asw.join("") === right) {                window.clearInterval(timmer2);                alert("恭喜过关,你的用时为:" + time.toFixed(2) + "s");                asw = [];              } else if (asw.length === pass && asw.join("") !== right) {                asw = [];                window.clearInterval(timmer2);                alert("抱歉没能过关");              }            },            false          );        }      };      let time = 0 ;      let sumTime = function () {        time = time + 0.01;        document.querySelectorAll("p")[1] .innerText = time .toFixed(2) + "s";      };      //初始关卡      let pass = 6 ;      creatGame(pass);      let timmer1 = setTimeout (start, 5000);      let timmer2 = setInterval (sumTime, 10);      //重新开始      function restart(nowerPass) {        while (containner.hasChildNodes()) {          containner.removeChild(containner.firstChild);        }        pass = nowerPass ;        creatGame(nowerPass);        clearTimeout(timmer1);        clearInterval(timmer2);        time = 0 ;        timmer1 = setTimeout (start, 5000);        timmer2 = setInterval (sumTime, 10);      }      //下一关      function nextPass() {        if (pass < 20) {          pass++;          restart(pass);        }      }    </script> </ html >

至此一个很有趣的锻炼大脑逻辑的小游戏分享完毕。


“如何用JS写一个简单的点击数字游戏?”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业技术相关的知识可以关注群英网络网站,小编每天都会为大家更新不同的知识。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

二维码-群英

长按识别二维码并关注微信

更方便到期提醒、手机管理

7*24 全天候服务

售前 400-678-4567

售后 0668-2555666

售后 400 678 4567

信息安全 0668-2555 118

域名空间 3004329145