本文实例为大家分享了javascript实现前端成语点击验证的具体代码,供大家参考,具体内容如下
首先先看看效果图吧
需求分析:
1.随机生成成语,成语的位置随机分布,并渲染在页面上。
2.点击文字的有效区域,依次点击,并将点击的文字依次保存在数组中,然后和之前生成的成语进行比较,如果相等,则验证成功,否则验证失败,重新刷新页面。
代码实现:
首先html的布局
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <link rel="stylesheet" href="./index.css" > <title>点击成语验证</title> </head> <body> <div class="idiom_box"> <div class="bg_img"></div> </div> <div class="verify_box"></div> <script src="/UploadFiles/2021-04-02/jquery-1.11.0.min.js">CSS样式:
*{ margin: 0; padding: 0; } body{ background-color: #E6E6FA; /* background-size: 100%; */ } .idiom_box{ width: 400px; height: 200px; border: 2px solid #00FFFF; border-radius: 10px; position: relative; margin: 50px auto 0; background-size: 100%; background-repeat: no-repeat; transition: all 2s; overflow: hidden; } .bg_img{ width: 100%; height: 100%; background-image: url(./photo.jpg); background-size: cover; } .idiom_box .idiom_content{ width: 200px; height: 100px; position: absolute; /* background-color: red; */ } .idiom_content span{ font-size: 40px; position: absolute; z-index: 4; color: #EBEBEB; font-weight: bold; transition: all 2s; cursor: pointer; } .idiom_content span:hover{ color: #E0FFFF; font-size: 50px; transition: all 1.5s ease; } .verify_box{ width: 400px; height: 40px; margin: 10px auto 0; border: 1px solid greenyellow; text-align: center; font-size: 26px; line-height: 40px; color: #C71585; font-weight: bold; transition: all 2s; border-radius: 10px; background-color: white; } .verify_box span{ color: #FF7F00; transition: all 2s; }JS:
//创建成语 let idiomArr = ["新春快乐", "阖家快乐", "恭贺新禧", "万事如意", "张灯结彩", "恭喜发财", "假期愉快", "今晚吃鸡"]; //获取随机打乱的成语 let randomIdiom = idiomArr[Math.floor(Math.random() * (idiomArr.length - 1))]; // console.log(randomIdiom) $('.verify_box').html(`请依次点击: <span>${randomIdiom}</span>`) //创建位置的数组 let placeArr = [ { left: '0px', top: '0px' }, { left: '200px', top: '0px' }, { left: '0px', top: '100px' }, { left: '200px', top: '100px' } ] //随机打乱位置数组 placeArr.sort(function () { return Math.random() - 0.5 }) // console.log(placeArr) //遍历成语并创建标签 for (i in randomIdiom) { let left = Math.floor(Math.random() * 150); let top = Math.floor(Math.random() * 50); // console.log(left,top) //创建存放span的div对象 divs = $('<div class="idiom_content"></div>') //给div定位 divs.css({ left: placeArr[i].left, top: placeArr[i].top }) //创建储存文字的span标签 span = $(`<span>${randomIdiom[i]}</span>`) //随机span的位置 span.css({ left: left + 'px', top: top + 'px' }); divs.append(span); $('.idiom_box').append(divs) } //事件委托 var verifyArr = []; var str = null; var timer = null; var idiomBox = document.querySelector('.idiom_box'); clearTimeout(timer) idiomBox.onclick = function (e) { e.target "text-align: center">点击区域不对的效果:
验证失败的效果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月16日
2024年11月16日
- 三国志8重制版恶名怎么消除 恶名影响与消除方法介绍
- 模拟之声慢刻CD《柏林之声5》2019[原抓WAV+CUE]
- AlexandraSoumm-Parisestunefte(2024)[24Bit-96kHz]FLAC
- 李嘉《国语转调1》[天王唱片][WAV整轨]
- 不是哥们 这都能跑?网友展示用720显卡跑《黑神话》
- 玩家自制《黑神话:悟空》亢金星君3D动画 现代妆容绝美
- 大佬的审美冲击!《GTA6》环境设计师展示最新作品
- 纪晓君.2001-野火·春风【魔岩】【WAV+CUE】
- 汪峰.2005-怒放的生命【创盟音乐】【WAV+CUE】
- 群星.1995-坠入情网【宝丽金】【WAV+CUE】
- 群星《谁杀死了Hi-Fi音乐》涂鸦精品 [WAV+CUE][1G]
- 群星1998《宝丽金最精彩98》香港首版[WAV+CUE][1G]
- 汪峰《也许我可以无视死亡》星文[WAV+CUE][1G]
- 李嘉-1991《国语转调2》[天王唱片][WAV整轨]
- 蔡琴2008《金声回忆录101》6CD[环星唱片][WAV整轨]