javascript实现前端成语点击验证
网络编程 2021-07-04 15:03www.168986.cn编程入门
这篇文章主要介绍了javascript实现前端成语点击验证,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了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="./jquery-1.11.0.min.js"></script> <script src="./index.js"></script> </body> </html>
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', : '0px' }, { left: '200px', : '0px' }, { left: '0px', : '100px' }, { left: '200px', : '100px' } ] //随机打乱位置数组 placeArr.sort(function () { return Math.random() - 0.5 }) // console.log(placeArr) //遍历成语并创建标签 for (i in randomIdiom) { let left = Math.floor(Math.random() 150); let = Math.floor(Math.random() 50); // console.log(left,) //创建存放span的div对象 divs = $('<div class="idiom_content"></div>') //给div定位 divs.css({ left: placeArr[i].left, : placeArr[i]. }) //创建储存文字的span标签 span = $(`<span>${randomIdiom[i]}</span>`) //随机span的位置 span.css({ left: left + 'px', : + '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 ? e.srcElement : e.target; if (e.target.tagName == 'SPAN') { // console.log(e.target.innerText); verifyArr.push(e.target.innerText); str = verifyArr.join('') if (str.length === randomIdiom.length) { if (str == randomIdiom) { // alert('验证成功!!') $('.verify_box').html('验证成功') } else { $('.verify_box').html('验证失败') timer = setTimeout(() => { location.reload() }, 1000); } } } else { alert('请点击有效区域') } }
验证成功的效果
点击区域不对的效果
验证失败的效果
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程