整活系列(一)——做个PC端打字小游戏

简介: 代码不光是我们用来工作的,也应该是我们用来娱乐的,今天就带着小伙伴们整个活!看完这篇文章,你会学会如何整活~小时候我记得有个软件叫做`金山打字通`,里面有个打字的飞机大战不知道有没有小伙伴玩过,当然我整不来他那么优秀,我只能做一个较为简单的(**低配版**),低的好像还真挺低。
大家好,我是Ned👀,一个刚刚入门前端未满两年的大三小学生🌹

未来路还长🎉, 一起努力加油吧❤~

前言

代码不光是我们用来工作的,也应该是我们用来娱乐的,今天就带着小伙伴们整个活!

看完这篇文章,你会学会如何整活~

小时候我记得有个软件叫做金山打字通,里面有个打字的飞机大战不知道有没有小伙伴玩过,当然我整不来他那么优秀,我只能做一个较为简单的(低配版),低的好像还真挺低。

先来看看效果吧:

打字游戏效果图.gif

开始整活

页面构成比较简单,一个是我们要打的字母,一个是下面的那行小字,用来做提示用。

     <div id="char">A</div>
     <div id="result">请在按键上按下屏幕上显示的字母</div>

接下来是做一些简单的布局,就是将内容居中,颜色等做一下调整,我们先贴代码,完后在进行一个细说。

    body{
        margin: 0;
        /*开启弹性布局,并让弹性布局中的子元素
        水平居中对齐,垂直居中对齐*/
        display: flex;
        /* 用于设置或检索弹性盒子元素在主轴(横轴)方向上的对齐方式 */
        justify-content: center;
        align-items: center;
        /*文字居中*/
        text-align: center;
        /*设置背景颜色的经向渐变*/
        background: radial-gradient(circle,#444,#000,#000);
    }
    #char{
        font-size: 400px;
        /*color: lightgreen;*/
        color: #90EE90;
        /*设置文字阴影*/
        /*text-shadow: 水平位置 垂直位置 模糊距离 阴影颜色*/
        /*位置可以为负值*/
        text-shadow: 0 0 50px #666;
    }
    #result{
        font-size: 20px;
        color: #888;
    }
    /*找到id为char及类名为error的div元素*/
    #char.error{
        color: red;

    }

我们定义了一个error类,用来做用户输入错的时候,将字母变成红色来给与用户提示。

背景用的径向渐变也挺有意思的,你必须要设定两个终止色,由中心到四周产生渐变色的效果,他的第一个参数有两种情况,椭圆跟圆,我们是可以自己进行选择的。

如果对此感兴趣也可以去菜鸟教程径向渐变看一看。

接下来我们来写我们的js逻辑处理。

先定义和获取我们需要的变量跟Dom节点

    //表示正确的次数
    var okCount=0;
    //错误的次数
    var errorCount=0;
    //获取显示字符的div
    var charBox=document.getElementById('char');
    //获取显示结果的div
    var result=document.getElementById('result');

正确率=正确的次数/总次数,我们再写一个函数来显示判断结果,显示正确跟错误的个数,还有正确率。

    //展示计算的结果
    function showResult(){
        var rate=100*okCount/(okCount+errorCount);
        //显示正确个数 错误个数 及正确率
        result.innerHTML='正确'+okCount+'个'+'错误'+errorCount+'个'+'正确率'+rate.toFixed(2)+'%';
    }
toFixed(2)的作用是保留两位小数

我们再写一个函数去随机获取A~Z这些英文字母的值。

var code = 0; // 存放随机数
 //获取A~Z之间的任意一个字符
    function show(){
        //获取[0,1)之间的一个随机数
        var rand=Math.random();
        //获取一个0到26之间的一个随机数(不包含26)
        code=rand*26;
        //Math.floor(a)对数字a向下取整,获取到一个小于等于a最近的整数
        //获取0~25之间任意一个整数
        code=Math.floor(code);
        //获取到65~90之间的任意整数
        code=code+65;
        //把ASCII的十进制编码转化成对应的字符
        //获取A~Z的任意一个字符
        var char=String.fromCharCode(code);
        //把字符显示在界面上
        charBox.innerHTML=char;
    }

利用随机数生成A~Z的ASCII码值,完后用String.fromCharCode转成英文字母并显示到页面上。

还有最后一个步骤就是监听用户的键盘按键事件,利用window.onkeydown事件来做。

    //键盘按下来的事件
    window.onkeydown=function(ev){
        //获取按键所对应的ASCII编码
        var key=ev.keyCode;
        //判断按键字母所对应的数字和随机获取的数字是否相等
        if(key==code){
            //按键正确,正确次数+1
            okCount ++;
            //当按键正确时,重新显示新的字符
            show();
        }else{
            //按键错误,错误次数+1
            errorCount ++;
        }   
        showResult();
    }

现在已经成功了,来看看效果吧!

打字游戏效果.gif

但是我们优秀的程序员当然想给用户略微(更好)的用户体验!所以我们来引入一个Animate.css动画库。

结合我们的小游戏,选择了zoomInshake两个动画,一个作为英文字母的出现伴随动画,另一个作为错误的时候提示用户的动画。我们在监听用户按键做出判断的时候来给我们的元素加上相对应动画的类名,并且在0.5s过后移除对应的类名就行了,防止发生冲突。

    //键盘按下来的事件
    window.onkeydown=function(ev){
        //获取按键所对应的ASCII十进制编码
        var key=ev.keyCode;
        //判断按键字母所对应的数字和随机获取的数字是否相等
        if(key==code){
            //按键正确,正确次数+1
            okCount ++;
            //当按键正确时,重新显示新的字符
            show();
            //添加正确的动画 通过js给div添加类名
            charBox.className ='animated zoomIn';
        }else{
            //按键错误,错误次数+1
            errorCount ++;
            //添加按键错误的动画
            charBox.className='animated shake error';
        }
        showResult();
        //0.5秒之后清除动画
        setTimeout(clearAnimated,500);
    }
    function clearAnimated(){
        //负责清除动画
        charBox.className='';
    }

到此为止,我们今日的整活就结束啦~

最后

希望大家快乐起来呀,老想着如何去实现产品经理给的需求会十分疲惫,在空闲之余不如来用我们擅长的代码整个活~

让自己,也让周围的人开心开心,也能让自己的心情变得轻松起来!

相关文章
|
8月前
|
存储 小程序 开发者
微信小程序猜拳游戏步骤及代码
微信小程序猜拳游戏步骤及代码
160 0
|
API Python
七夕节特辑,浏览器桌面太无聊,为什么不做个挂件来陪自己呢?
七夕节特辑,浏览器桌面太无聊,为什么不做个挂件来陪自己呢?
121 0
|
Ubuntu Shell Android开发
微信小游戏跳一跳外挂教程(安卓版)
微信小游戏跳一跳外挂教程(安卓版)
157 0
|
Python
python小游戏——乒乓球大战2.0版本の双人联机对战功能的实现
python小游戏——乒乓球大战2.0版本の双人联机对战功能的实现
301 0
|
小程序
如何制作一个塔防小游戏(三)
嗨!大家好,我是小蚂蚁。今天我们继续分享制作一个塔防小游戏的第三节,如何创建不同类型的敌人,以及如何利用表格来编辑数据以及创建敌人。
140 0
|
存储
微信小游戏开发实战14-闯关模式的实现
本文主要内容是介绍精致1010闯关模式的设计和实现思路。 如果你没有任何的游戏开发经验,欢迎阅读我的“人人都能做游戏”系列教程,它会手把手的教你做出自己的第一个小游戏。
186 0
|
人工智能 网络协议 网络性能优化
【毕设参考】HaaS Python 云端一体AI【手势识别】窝在家里看电视不想动?想换台懒得找遥控器?试试解锁智能设备新玩法
【毕设参考】HaaS Python 云端一体AI【手势识别】窝在家里看电视不想动?想换台懒得找遥控器?试试解锁智能设备新玩法
179 0
|
前端开发 JavaScript
3D魔方小游戏(附源码)
一说到魔方 想必大家都熟悉的不能再熟悉了 自己或者曾今自己的朋友非常喜欢玩的一款游戏 言归正卷 那么实用前端的技术怎么实现3D的魔方制作呢 从以下几个方面就不难发现 前端实现3D魔方都得需要用上这些技术栈
|
前端开发
仿王者荣耀网页-前端网页技术设计完整精美源码HTML+CSS+JS
仿王者荣耀网页-前端网页技术设计完整精美源码HTML+CSS+JS
431 0
仿王者荣耀网页-前端网页技术设计完整精美源码HTML+CSS+JS
uiu
|
JavaScript 前端开发
制作别踩白块网页小游戏
制作别踩白块网页小游戏
uiu
163 0
制作别踩白块网页小游戏