html+css+js 实现键盘按键,练习盲打!

做一个合格的键盘侠

在这里插入图片描述

<html>
  <head>
    <meta charset="utf-8" />
    <script
      id="jqbb"
      src="https://libs.baidu.com/jquery/1.11.1/jquery.min.js"
    ></script>

    <style type="text/css">
      body {
     
     
        background-color: black;
        font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
        font-weight: 500;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        height: 100vh;
      }

      .title {
     
     
        color: mintcream;
        text-transform: uppercase;
        margin-top: 3em;
        margin-bottom: 3em;
        font-size: 1em;
        letter-spacing: 0.3em;
      }

      .keyboard {
     
     
        display: flex;
        flex-direction: column;
      }

      .row {
     
     
        list-style: none;
        display: flex;
      }

      li {
     
     
        height: 3em;
        width: 3em;
        color: rgba(0, 0, 0, 0.7);
        border-radius: 0.4em;
        line-height: 3em;
        letter-spacing: 1px;
        margin: 0.4em;
        transition: 0.3s;
        text-align: center;
        font-size: 1em;
      }

      #tab {
     
     
        width: 5em;
      }

      #caps {
     
     
        width: 6em;
      }

      #left-shift {
     
     
        width: 8em;
      }

      #enter {
     
     
        width: 6em;
      }

      #right-shift {
     
     
        width: 8em;
      }

      #back {
     
     
        width: 5em;
      }

      .pinky {
     
     
        background-color: crimson;
        border: 2px solid crimson;
      }

      .pinky.selected {
     
     
        color: crimson;
      }

      .ring {
     
     
        background-color: coral;
        border: 2px solid coral;
      }

      .ring.selected {
     
     
        color: coral;
      }

      .middle {
     
     
        background-color: darkorange;
        border: 2px solid darkorange;
      }

      .middle.selected {
     
     
        color: darkorange;
      }

      .pointer1st {
     
     
        background-color: gold;
        border: 2px solid gold;
      }

      .pointer1st.selected {
     
     
        color: gold;
      }

      .pointer2nd {
     
     
        background-color: khaki;
        border: 2px solid khaki;
      }

      .pointer2nd.selected {
     
     
        color: khaki;
      }

      .fill-out-key {
     
     
        background-color: slategrey;
        border: 2px solid slategrey;
      }

      .selected {
     
     
        background-color: transparent;
        -webkit-animation: vibrate-1 0.3s linear infinite both;
        animation: vibrate-1 0.3s linear infinite both;
      }

      /* ----------------------------------------------
 * Generated by Animista
 * Licensed under FreeBSD License.
 * See http://animista.net/license for more info. 
 * w: http://animista.net, t: @cssanimista
 * ---------------------------------------------- */

      .hit {
     
     
        -webkit-animation: hit 0.3s cubic-bezier(0.39, 0.575, 0.565, 1) both;
        animation: hit 0.3s cubic-bezier(0.39, 0.575, 0.565, 1) both;
      }

      @-webkit-keyframes hit {
     
     
        0% {
     
     
          -webkit-transform: scale(1.2);
          transform: scale(1.2);
        }
        100% {
     
     
          -webkit-transform: scale(1);
          transform: scale(1);
        }
      }

      @keyframes hit {
     
     
        0% {
     
     
          -webkit-transform: scale(1.2);
          transform: scale(1.2);
        }
        100% {
     
     
          -webkit-transform: scale(1);
          transform: scale(1);
        }
      }

      @-webkit-keyframes vibrate-1 {
     
     
        0% {
     
     
          -webkit-transform: translate(0);
          transform: translate(0);
        }
        20% {
     
     
          -webkit-transform: translate(-2px, 2px);
          transform: translate(-2px, 2px);
        }
        40% {
     
     
          -webkit-transform: translate(-2px, -2px);
          transform: translate(-2px, -2px);
        }
        60% {
     
     
          -webkit-transform: translate(2px, 2px);
          transform: translate(2px, 2px);
        }
        80% {
     
     
          -webkit-transform: translate(2px, -2px);
          transform: translate(2px, -2px);
        }
        100% {
     
     
          -webkit-transform: translate(0);
          transform: translate(0);
        }
      }

      @keyframes vibrate-1 {
     
     
        0% {
     
     
          -webkit-transform: translate(0);
          transform: translate(0);
        }
        20% {
     
     
          -webkit-transform: translate(-2px, 2px);
          transform: translate(-2px, 2px);
        }
        40% {
     
     
          -webkit-transform: translate(-2px, -2px);
          transform: translate(-2px, -2px);
        }
        60% {
     
     
          -webkit-transform: translate(2px, 2px);
          transform: translate(2px, 2px);
        }
        80% {
     
     
          -webkit-transform: translate(2px, -2px);
          transform: translate(2px, -2px);
        }
        100% {
     
     
          -webkit-transform: translate(0);
          transform: translate(0);
        }
      }
    </style>
  </head>

  <body>
    <h1 class="title">盯着屏幕</h1>
    <div class="keyboard">
      <ul class="row row-0">
        <li class="pinky" id="esc">ESC</li>
        <li class="pinky" id="1">1</li>
        <li class="ring" id="2">2</li>
        <li class="middle" id="3">3</li>
        <li class="pointer1st" id="4">4</li>
        <li class="pointer2nd" id="5">5</li>
        <li class="pointer2nd" id="6">6</li>
        <li class="pointer1st" id="7">7</li>
        <li class="middle" id="8">8</li>
        <li class="ring" id="9">9</li>
        <li class="pinky" id="10">0</li>
        <li class="pinky">-</li>
        <li class="pinky">+</li>
        <li class="pinky" id="back">BACK</li>
      </ul>
      <ul class="row row-1">
        <li class="pinky" id="tab">TAB</li>
        <li class="pinky" id="Q">Q</li>
        <li class="ring" id="W">W</li>
        <li class="middle" id="E">E</li>
        <li class="pointer1st" id="R">R</li>
        <li class="pointer2nd" id="T">T</li>
        <li class="pointer2nd" id="Y">Y</li>
        <li class="pointer1st" id="U">U</li>
        <li class="middle" id="I">I</li>
        <li class="ring" id="O">O</li>
        <li class="pinky" id="P">P</li>
        <li class="pinky">[</li>
        <li class="pinky">]</li>
        <li class="pinky">\</li>
      </ul>
      <ul class="row row-2">
        <li class="pinky" id="caps">CAPS</li>
        <li class="pinky" id="A">A</li>
        <li class="ring" id="S">S</li>
        <li class="middle" id="D">D</li>
        <li class="pointer1st" id="F">F</li>
        <li class="pointer2nd" id="G">G</li>
        <li class="pointer2nd" id="H">H</li>
        <li class="pointer1st" id="J">J</li>
        <li class="middle" id="K">K</li>
        <li class="ring" id="L">L</li>
        <li class="pinky">:</li>
        <li class="pinky">''</li>
        <li class="pinky" id="enter">ENTER</li>
      </ul>
      <ul class="row row-3">
        <li class="pinky" id="left-shift">SHIFT</li>
        <li class="pinky" id="Z">Z</li>
        <li class="ring" id="X">X</li>
        <li class="middle" id="C">C</li>
        <li class="pointer1st" id="V">V</li>
        <li class="pointer2nd" id="B">B</li>
        <li class="pointer2nd" id="N">N</li>
        <li class="pointer1st" id="M">M</li>
        <li class="middle">,</li>
        <li class="ring">.</li>
        <li class="pinky">;</li>
        <li class="pinky" id="right-shift">SHIFT</li>
      </ul>
    </div>
    <h1 class="title">手放在键盘上</h1>
  </body>
  <script>
    const keys = [..."ABCDEFGHIJKLMNOPQRSTUVWXYZ"];

    const timestamps = [];

    timestamps.unshift(getTimestamp());

    function getRandomNumber(min, max) {
     
     
      min = Math.ceil(min);
      max = Math.floor(max);
      return Math.floor(Math.random() * (max - min + 1)) + min;
    }

    function getRandomKey() {
     
     
      return keys[getRandomNumber(0, keys.length - 1)];
    }

    function targetRandomKey() {
     
     
      const key = document.getElementById(getRandomKey());
      key.classList.add("selected");
      let start = Date.now();
    }

    function getTimestamp() {
     
     
      return Math.floor(Date.now() / 1000);
    }

    document.addEventListener("keyup", (event) => {
     
     
      const keyPressed = String.fromCharCode(event.keyCode);
      const keyElement = document.getElementById(keyPressed);
      const highlightedKey = document.querySelector(".selected");

      keyElement.classList.add("hit");
      keyElement.addEventListener("animationend", () => {
     
     
        keyElement.classList.remove("hit");
      });

      if (keyPressed === highlightedKey.innerHTML) {
     
     
        timestamps.unshift(getTimestamp());
        const elapsedTime = timestamps[0] - timestamps[1];
        console.log(`Character per minute ${
       
       60 / elapsedTime}`);
        highlightedKey.classList.remove("selected");
        targetRandomKey();
      }
    });

    targetRandomKey();
  </script>
</html>

前端 零基础 入门到高级教学 (视频+源码+开发软件+学习资料+面试题) 一整套

在这里插入图片描述

1.看到这里了就 [点赞+好评+收藏] 支持下吧,你的「点赞,好评,收藏」是我创作的动力。

2.关注我~ 每天带你学习 :各种前端插件、3D炫酷效果、图片展示、文字效果、以及整站模板 、大学生毕业设计模板 等! 「在这里有好多 前端 开发者,会讨论 前端 Node 知识,互相学习」!

3.以上内容技术相关问题可以留言/私信交流,也可以关注↓下方公众号 获取更多源码 !

在这里插入图片描述

更多源码

❤女朋友生日❤ HTML+css3+js 实现抖音炫酷樱花3D相册 (含背景音乐)程序员表白必备

❤炫酷烟花表白❤ html+css+js 放一场浪漫烟花秀(含音乐) 程序员表白

❤vue/react+echarts❤ 大屏可视化数据平台实战项目分享 (附源码)

❤七夕情人节❤html+css+js 漫天飞雪3D相册(含音乐自定义文字) 程序员表白必备

❤唯美满天星❤ html+css+js炫酷3D相册(含音乐可自定义文字)程序员表白必备

❤html+css+js❤ 白云飘动3D相册(含音乐)程序员表白必备

❤[前端永久免费部署上线工具] 解决不需要服务器就能将项目部署上线问题!

这个冬天, 我是这样表白的 ❉html+css+js❉ 绘制冬季下雪3D相册 (521程序员表白代码大公开)

新年祝福❤雪花飘落❤ html+css3+js 实现3D相册开关闭合旋转(情人节生日表白)必备

❤爱情墙❤html5+css3+js 实现全屏七夕表白页面 (可自定义文字相片)

❤超炫100套❤vue+echarts大屏可视化数据平台实战项目模板 (vuereact 均可使用)

抖音❤超火| html+css+js 流星雨3D相册(表白必备)制作教程来啦!

前端❤ html+css+js 实现1000个超炫酷特效(附源码)

web前端❤基于html+css+js 仿JD天猫电商平台功能齐全(免费附源码)

抖音超火❤ html+css+js 实现炫酷3D立方图像库(免费附源码)

抖音超火❤ html+css+js 实现炫酷3D魔方(免费附源码)

抖音超火❤流动爱心 html+css+js (免费附源码)

抖音超火❤罗盘时钟html+css+js (免费附源码)

亲测有效❤抖音视频去水印 ( 附源码| 仅供学习参考)

css3 实现3D旋转立方体(免费附源码)

css3 实现3D立体时钟(免费附源码)

❤雪花飘落❤ html+css+js实现2021新年倒计时特效(附源码)

七夕情人节 ❤html+css+j❤实现满屏爱心特效(程序员表白)

一款乾坤八卦风水罗盘旋转CSS3动画,给人一种玄机重重的感觉(附源码)

微信公众号开发 ❤一篇就够 [推荐收藏]

微信小程序入门教学❤ 手摸手撸小程序,一篇就够!

猜你喜欢

转载自blog.csdn.net/weixin_54234482/article/details/114655674