电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

JavaScript實(shí)現(xiàn)打字游戲

瀏覽:7日期:2023-06-08 16:12:07

本文實(shí)例為大家分享了JavaScript實(shí)現(xiàn)打字游戲的具體代碼,供大家參考,具體內(nèi)容如下

效果圖:

JavaScript實(shí)現(xiàn)打字游戲

JavaScript實(shí)現(xiàn)打字游戲

JavaScript實(shí)現(xiàn)打字游戲

需求分析:

1、在char這個(gè)div里面顯示要輸入的字母,大寫(xiě)2、在result這個(gè)div里面時(shí)時(shí)顯示正確率,比如98%3、給文檔綁定按鍵事件4、如果輸入的內(nèi)容和char里面一致,顯示正確動(dòng)畫(huà):animated zoomIn,并更換輸入的字母5、如果輸入的內(nèi)容和char里面不一致,顯示錯(cuò)誤動(dòng)畫(huà):animated shake error6、不管是正確還是錯(cuò)誤都時(shí)時(shí)更新result里面的正確率

源代碼:

HTML部分

<mian> <div id='char'>A</div> <div id='result'>請(qǐng)?jiān)诎存I上按下屏幕上顯示的字母</div></mian>

css部分

1.為了實(shí)現(xiàn)一些特效,先創(chuàng)建一個(gè)animate.css文件,在封裝一些動(dòng)畫(huà)效果放里面

/*animate.css*/.animated { -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-fill-mode: both; animation-fill-mode: both;}.animated.infinite { -webkit-animation-iteration-count: infinite; animation-iteration-count: infinite;}.animated.hinge { -webkit-animation-duration: 2s; animation-duration: 2s;}.animated.flipOutX,.animated.flipOutY,.animated.bounceIn,.animated.bounceOut { -webkit-animation-duration: .75s; animation-duration: .75s;}@-webkit-keyframes zoomIn { from { opacity: 0; -webkit-transform: scale3d(.3, .3, .3); transform: scale3d(.3, .3, .3); } 50% { opacity: 1; }}@keyframes zoomIn { from { opacity: 0; -webkit-transform: scale3d(.3, .3, .3); transform: scale3d(.3, .3, .3); } 50% { opacity: 1; }}.zoomIn { -webkit-animation-name: zoomIn; animation-name: zoomIn;} .animated { -webkit-animation-duration: 1s; animation-duration: 1s; -webkit-animation-fill-mode: both; animation-fill-mode: both;}@-webkit-keyframes shake { from, to { -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); } 10%, 30%, 50%, 70%, 90% { -webkit-transform: translate3d(-10px, 0, 0); transform: translate3d(-10px, 0, 0); } 20%, 40%, 60%, 80% { -webkit-transform: translate3d(10px, 0, 0); transform: translate3d(10px, 0, 0); }}@keyframes shake { from, to { -webkit-transform: translate3d(0, 0, 0); transform: translate3d(0, 0, 0); } 10%, 30%, 50%, 70%, 90% { -webkit-transform: translate3d(-10px, 0, 0); transform: translate3d(-10px, 0, 0); } 20%, 40%, 60%, 80% { -webkit-transform: translate3d(10px, 0, 0); transform: translate3d(10px, 0, 0); }}.shake { -webkit-animation-name: shake; animation-name: shake;}

2.css主體代碼,無(wú)動(dòng)畫(huà)特效版

<style> body { margin: 0; /*開(kāi)啟彈性布局,并讓彈性布局中的子元素 水平居中對(duì)齊,垂直居中對(duì)齊*/ display: flex; justify-content: center; align-items: center; /*文字居中*/ text-align: center; /*設(shè)置背景顏色的經(jīng)像漸變*/ background: radial-gradient(circle, #444, #111, #000); } #char { font-size: 400px; color: lightgreen; /*設(shè)置文字陰影*/ /*text-shadow: 水平位置 垂直位置 模糊距離 陰影顏色*/ /*位置可以為負(fù)值*/ text-shadow: 0 0 50px #666; } #result { font-size: 20px; color: #888; } /*找到id為char及類(lèi)名為error的div元素*/ #char.error { color: red; }</style>

JavaScript部分

1.為了簡(jiǎn)化代碼,先封裝一些常用的自定義構(gòu)造函數(shù)

<script>// 定義一個(gè)函數(shù):rand// 參數(shù):最小整數(shù),最大整數(shù)// 返回:兩個(gè)整數(shù)之間的一個(gè)隨機(jī)整數(shù)function rand(min, max) { return parseInt(Math.random() * (max - min + 1)) + min;} </script>

2.js主體部分,需要用到封裝的函數(shù),調(diào)用即可

<script> // 獲取相關(guān)元素 var charDiv = document.getElementById(’char’); var resultDiv = document.getElementById(’result’); // code用于記錄頁(yè)面上的字母的編碼,使用全局變量,到處都可以使用 var code, tirme; var rightNum = 0;//正確次數(shù) var wrongNum = 0;//錯(cuò)誤次數(shù) // 1 在char這個(gè)div里面顯示要輸入的字母,大寫(xiě) showChar(); // 3 給文檔綁定按鍵事件 document.onkeyup = function (e) { // 事件對(duì)象 e = window.event || e; // 獲取按鍵編碼 var keyCode = e.keyCode || e.which; // 4 如果輸入的內(nèi)容和char里面一致 if (keyCode == code) { // 顯示正確動(dòng)畫(huà):animated zoomIn charDiv.className = 'animated zoomIn'; rightNum++; showChar() } // 5 如果輸入的內(nèi)容和char里面不一致 else { // 顯示錯(cuò)誤動(dòng)畫(huà):animated shake error charDiv.className = 'animated shake error'; wrongNum++ } // 為了下一次有動(dòng)畫(huà),在本次動(dòng)畫(huà)完后要移除類(lèi)名 setTimeout(function () { charDiv.className = ''; }, 500) // 6 不管是正確還是錯(cuò)誤都時(shí)時(shí)更新result里面的正確率 // 正確率 = 正確次/總次數(shù) resultDiv.innerHTML = '正確率:' + parseInt(rightNum / (rightNum + wrongNum) * 100) + '%' } // 函數(shù)功能:在char這個(gè)div里面隨機(jī)顯示要輸入的字母:大寫(xiě) function showChar() { // 先隨機(jī)出一個(gè)字母編碼 code = rand(65, 90); // 變成一個(gè)字母 var char = String.fromCharCode(code); // 顯示在char這個(gè)div里面 charDiv.innerHTML = char; }</script>

總代碼

<html><head> <meta charset='utf-8'> <title>打字游戲</title> <!--引入animate.css動(dòng)畫(huà)庫(kù)--> <link rel='stylesheet' href='http://www.hdgsjgj.cn/bcjs/animate.css' > <style> body { margin: 0; /*開(kāi)啟彈性布局,并讓彈性布局中的子元素 水平居中對(duì)齊,垂直居中對(duì)齊*/ display: flex; justify-content: center; align-items: center; /*文字居中*/ text-align: center; /*設(shè)置背景顏色的經(jīng)像漸變*/ background: radial-gradient(circle, #444, #111, #000); } #char { font-size: 400px; color: lightgreen; /*設(shè)置文字陰影*/ /*text-shadow: 水平位置 垂直位置 模糊距離 陰影顏色*/ /*位置可以為負(fù)值*/ text-shadow: 0 0 50px #666; } #result { font-size: 20px; color: #888; } /*找到id為char及類(lèi)名為error的div元素*/ #char.error { color: red; } </style></head><body> <mian> <div id='char'>A</div> <div id='result'>請(qǐng)?jiān)诎存I上按下屏幕上顯示的字母</div> </mian></body></html><script> // 定義一個(gè)函數(shù):rand // 參數(shù):最小整數(shù),最大整數(shù) // 返回:兩個(gè)整數(shù)之間的一個(gè)隨機(jī)整數(shù) function rand(min, max) { return parseInt(Math.random() * (max - min + 1)) + min; }</script><script> // 獲取相關(guān)元素 var charDiv = document.getElementById(’char’); var resultDiv = document.getElementById(’result’); // code用于記錄頁(yè)面上的字母的編碼,使用全局變量,到處都可以使用 var code, tirme; var rightNum = 0;//正確次數(shù) var wrongNum = 0;//錯(cuò)誤次數(shù) // 1 在char這個(gè)div里面顯示要輸入的字母,大寫(xiě) showChar(); // 3 給文檔綁定按鍵事件 document.onkeyup = function (e) { // 事件對(duì)象 e = window.event || e; // 獲取按鍵編碼 var keyCode = e.keyCode || e.which; // 4 如果輸入的內(nèi)容和char里面一致 if (keyCode == code) { // 顯示正確動(dòng)畫(huà):animated zoomIn charDiv.className = 'animated zoomIn'; rightNum++; showChar() } // 5 如果輸入的內(nèi)容和char里面不一致 else { // 顯示錯(cuò)誤動(dòng)畫(huà):animated shake error charDiv.className = 'animated shake error'; wrongNum++ } // 為了下一次有動(dòng)畫(huà),在本次動(dòng)畫(huà)完后要移除類(lèi)名 setTimeout(function () { charDiv.className = ''; }, 500) // 6 不管是正確還是錯(cuò)誤都時(shí)時(shí)更新result里面的正確率 // 正確率 = 正確次/總次數(shù) resultDiv.innerHTML = '正確率:' + parseInt(rightNum / (rightNum + wrongNum) * 100) + '%' } // 函數(shù)功能:在char這個(gè)div里面隨機(jī)顯示要輸入的字母:大寫(xiě) function showChar() { // 先隨機(jī)出一個(gè)字母編碼 code = rand(65, 90); // 變成一個(gè)字母 var char = String.fromCharCode(code); // 顯示在char這個(gè)div里面 charDiv.innerHTML = char; }</script>

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 多功能三相相位伏安表-变压器短路阻抗测试仪-上海妙定电气 | 除甲醛公司-甲醛检测-广西雅居环境科技有限公司 | 送料机_高速冲床送料机_NC伺服滚轮送料机厂家-东莞市久谐自动化设备有限公司 | 岛津二手液相色谱仪,岛津10A液相,安捷伦二手液相,安捷伦1100液相-杭州森尼欧科学仪器有限公司 | 厂房出租-厂房规划-食品技术-厂房设计-厂房装修-建筑施工-设备供应-设备求购-龙爪豆食品行业平台 | 天津次氯酸钠酸钙溶液-天津氢氧化钠厂家-天津市辅仁化工有限公司 | 宠物店加盟_宠物连锁店_开宠物店-【派多格宠物】 | 水厂污泥地磅|污泥处理地磅厂家|地磅无人值守称重系统升级改造|地磅自动称重系统维修-河南成辉电子科技有限公司 | 二手色谱仪器,十万分之一分析天平,蒸发光检测器,电位滴定仪-湖北捷岛科学仪器有限公司 | 农业仪器网 - 中国自动化农业仪器信息交流平台 | 视觉检测设备_自动化检测设备_CCD视觉检测机_外观缺陷检测-瑞智光电 | 气弹簧定制-气动杆-可控气弹簧-不锈钢阻尼器-工业气弹簧-可调节气弹簧厂家-常州巨腾气弹簧供应商 | 线材成型机,线材折弯机,线材成型机厂家,贝朗自动化设备有限公司1 | 企业管理培训,企业培训公开课,企业内训课程,企业培训师 - 名课堂企业管理培训网 | 手机存放柜,超市储物柜,电子储物柜,自动寄存柜,行李寄存柜,自动存包柜,条码存包柜-上海天琪实业有限公司 | 低温等离子清洗机(双气路进口)-嘉润万丰 | 通风天窗,通风气楼,屋顶通风天窗,屋顶通风天窗公司 | 药品冷藏箱厂家_低温冰箱_洁净工作台-济南欧莱博电子商务有限公司官网 | 山东集装箱活动房|济南集装箱活动房-济南利森集装箱有限公司 | 蓝牙音频分析仪-多功能-四通道-八通道音频分析仪-东莞市奥普新音频技术有限公司 | 电机修理_二手电机专家-河北豫通机电设备有限公司(原石家庄冀华高压电机维修中心) | 机器视觉检测系统-视觉检测系统-机器视觉系统-ccd检测系统-视觉控制器-视控一体机 -海克易邦 | 锤式粉碎机,医药粉碎机,锥式粉碎机-无锡市迪麦森机械制造有限公司 | 海鲜池-专注海鲜鱼缸、移动海鲜缸、饭店鱼缸设计定做-日晟水族厂家 | 底部填充胶_电子封装胶_芯片封装胶_芯片底部填充胶厂家-东莞汉思新材料 | 欧必特空气能-商用空气能热水工程,空气能热水器,超低温空气源热泵生产厂家-湖南欧必特空气能公司 | 氢氧化钙设备_厂家-淄博工贸有限公司 | 隔离变压器-伺服变压器--输入输出电抗器-深圳市德而沃电气有限公司 | 巩义市科瑞仪器有限公司| 温州在线网| 曙光腾达官网-天津脚手架租赁-木板架出租-移动门式脚手架租赁「免费搭设」 | 酒糟烘干机-豆渣烘干机-薯渣烘干机-糟渣烘干设备厂家-焦作市真节能环保设备科技有限公司 | 鑫铭东办公家具一站式定制采购-深圳办公家具厂家直销 | 烟雾净化器-滤筒除尘器-防爆除尘器-除尘器厂家-东莞执信环保科技有限公司 | 铝扣板-铝方通-铝格栅-铝条扣板-铝单板幕墙-佳得利吊顶天花厂家 elisa试剂盒价格-酶联免疫试剂盒-猪elisa试剂盒-上海恒远生物科技有限公司 | 流量检测仪-气密性检测装置-密封性试验仪-东莞市奥图自动化科技有限公司 | 抖音短视频运营_企业网站建设_网络推广_全网自媒体营销-东莞市凌天信息科技有限公司 | 聚氨酯保温钢管_聚氨酯直埋保温管道_聚氨酯发泡保温管厂家-沧州万荣防腐保温管道有限公司 | 焊接烟尘净化器__焊烟除尘设备_打磨工作台_喷漆废气治理设备 -催化燃烧设备 _天津路博蓝天环保科技有限公司 | 丹佛斯压力传感器,WISE温度传感器,WISE压力开关,丹佛斯温度开关-上海力笙工业设备有限公司 | 电脑刺绣_绣花厂家_绣花章仔_织唛厂家-[源欣刺绣]潮牌刺绣打版定制绣花加工厂家 |